docker 构建jar包/vue镜像以及发布

1、maven 对项目进行jar/war打包:

如:my-notepad-service-1.006.jar

2、构建镜像:

新建Dockerfile内容有:

shell 复制代码
FROM openjdk:8-jdk-alpine
# 作者
MAINTAINER Yang douya
# jar包添加到镜像中 第一个是maven打包jar 第二个为在镜像中得jar名称 通常aven打包jar都会价版本号 镜像版本不用
ADD  my-notepad-service.jar  my-notepad-service.jar
# 应用中有中文标识 特别是验证码会报java.lang.NullPointerException at sun.awt.FontConfiguration.getVersion异常 解决增加字体
RUN echo -e 'https://mirrors.aliyun.com/alpine/v3.6/main/\nhttps://mirrors.aliyun.com/alpine/v3.6/community/' > /etc/apk/repositories \
 && apk update \
 && apk upgrade \
 && apk --no-cache add ttf-dejavu fontconfig

# 解决时差8小时问题
ENV TZ=Asia/Shanghai
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
# 暴露端口号
EXPOSE 8085
# 容器启动之后要执行的命令
ENTRYPOINT ["java", "-jar", "my-notepad-service.jar"]

以上Dockerfile设置时区,但是运行之后容器依然存在时间错误问题,所以必须在启动中加入同宿主机时间同步

-v /etc/localtime:/etc/localtime

对于已经存在了的容器修改时间

docker exec -it [容器] /bin/sh

执行下方命令同步宿主机时间

ln -fs /usr/share/zoneinfo/Asia/Shanghai /etc/localtime

如果执行上方命令出错 需要安装时间插件 tzdata

shell 复制代码
# centos
yum update && yum  install -y tzdata
# ububtu
apt-get update && apt-get install -y tzdata

将Dockerfile和my-notepad-service-1.006.jar jar文件放到同一个目录下

使用命令构建镜像,注意最后一个.为DockerFile文件和jar文件在同一个目录:

shell 复制代码
docker build -t my-notepad-service:1.006 .

docker image 查看即可

执行启动镜像-v /etc/localtime:/etc/localtime 目的是保证容器时间和宿主机时间一致

shell 复制代码
docker run --name my-notepad-service \
-p 8085:8085 \
-v /etc/localtime:/etc/localtime \
-d my-notepad-service:1.006

构建vue项目

先安装nginx:1.24.0后面全部使用该镜像依赖

1、npm run build XXX 打包vue项目

2、编写Dockerfile

shell 复制代码
# 设置基础镜像,这里使用最新的nginx镜像,前面已经拉取过了
FROM nginx:1.24.0
# 定义作者
MAINTAINER Yang Douya 
# 将dist文件中的内容复制到 /usr/share/nginx/html/ 这个目录下面
COPY dist/ /usr/share/nginx/html/

3、将打包好得dist目录同Dockerfile上传到服务器某个目录下

4、执行docker 构建

shell 复制代码
docker build -t my-notepad-admin:1.001 .
shell 复制代码
# 运行
docker run --name=my-notepad-admin \
-p 7681:80 \
-d my-notepad-admin:1.001
相关推荐
老前端的功夫2 小时前
Vue 3 vs Vue 2 深度解析:从架构革新到开发体验全面升级
前端·vue.js·架构
狗哥哥3 小时前
Vue 3 动态菜单渲染优化实战:从白屏到“零延迟”体验
前端·vue.js
青青很轻_3 小时前
Vue自定义拖拽指令架构解析:从零到一实现元素自由拖拽
前端·javascript·vue.js
蜗牛攻城狮3 小时前
Vue 中 `scoped` 样式的实现原理详解
前端·javascript·vue.js
专家大圣3 小时前
摆脱局域网束缚!Neko+cpolar 让跨网共享成日常
服务器·网络·docker·内网穿透·cpolar
Haooog4 小时前
Docker面试题(不定时更新)
java·docker·面试
q_19132846954 小时前
基于SpringBoot2+Vue2的行业知识答题考试系统
java·vue.js·spring boot·mysql·毕业设计·计算机毕业设计·演示文稿
树下水月4 小时前
docker 启动后 如何通过对应的进程 找docker-compose.yaml 编排文件
运维·docker·容器
凯子坚持 c4 小时前
Docker 网络管理深度解析与实践指南
运维·docker·容器
kevin_水滴石穿4 小时前
在镜像生成时从内网获取字体安装包并配置
linux·docker·容器