1.7.1 环境信息

代码地址:https://gitee.com/dukuan/demo-ui.git

构建命令:mvn clean package

Java 版本:jdk 1.8

构建镜像:registry.cn-hangzhou.aliyuncs.com/abroad_images/node:16.17.0-apline-cnpm

1.7.2 构建及容器化

1、在node01主机(10.0.0.21)下载源码

# 宿主机上创建项目目录
[root@node01 ~]# mkdir springcloud

# 下载源码
[root@k8s-node01 ~]# cd springcloud/
[root@k8s-node01 springcloud]# git clone https://gitee.com/dukuan/demo-ui.git

# 宿主机上创建缓存目录(如果上面做过此步骤可忽略)
[root@k8s-node01 springcloud]# mkdir -p /data/m2

2、在node01主机(10.0.0.21)启动临时容器,进行构建

# 启动临时容器
[root@node01 ~]# cd /root/springcloud
[root@k8s-node01 springcloud]# 
docker run -it --rm \
  -v /data/m2:/root/.m2 \
  -v "$(pwd)/demo-ui:/mnt" \
  registry.cn-hangzhou.aliyuncs.com/abroad_images/node:16.17.0-apline-cnpm sh
/ # cd /mnt/
/mnt # sed -i 's/"@vitejs\/plugin-vue": "^5.0.4"/"@vitejs\/plugin-vue": "^4.3.4"/' package.json
/mnt # sed -i 's/"vite": "^5.2.0"/"vite": "^4.4.9"/' package.json
/mnt # npm install --registry=https://registry.npmmirror.com
/mnt # npm run build

# 出现✓字样,代表成功
> demo-ui@0.0.0 build
> vite build

vite v4.5.9 building for production...
✓ 64 modules transformed.
dist/index.html                  0.45 kB  gzip:  0.29 kB
dist/assets/index-819d4460.css   1.27 kB  gzip:  0.65 kB
dist/assets/index-c04d2758.js   94.87 kB  gzip: 37.59 kB
✓ built in 1.22s

# 检查宿主机目录
[root@k8s-node01 springcloud]# ll /root/springcloud/demo-ui/dist/
总用量 8
drwxr-xr-x 2 root root   57  3月 23 10:55 assets
-rw-r--r-- 1 root root  449  3月 23 10:55 index.html
-rw-r--r-- 1 root root 1497  3月 23 10:55 vite.svg

3、在node01主机(10.0.0.21)编写Dockfile文件

# 宿主机上同样查看,观察到已生成target目录
[root@k8s-node01 ~]# cd /root/springcloud/demo-ui/
[root@k8s-node01 demo-ui]# ll
总用量 80
drwxr-xr-x  3 root root    54  3月 23 10:55 dist
-rw-r--r--  1 root root   357  3月 23 10:54 index.html
drwxr-xr-x 43 root root  4096  3月 23 10:55 node_modules
-rw-r--r--  1 root root   335  3月 23 10:54 package.json
-rw-r--r--  1 root root 59193  3月 23 10:55 package-lock.json
drwxr-xr-x  2 root root    22  3月 23 10:54 public
-rw-r--r--  1 root root   440  3月 23 10:54 README.md
drwxr-xr-x  4 root root    85  3月 23 10:54 src
-rw-r--r--  1 root root   157  3月 23 10:54 vite.config.js

# 编写Dockfile文件
[root@k8s-node01 ~]# cd /root/springcloud/demo-ui/
[root@k8s-node01 demo-ui]# vim Dockerfile
# 基础镜像可以按需修改,可以更改为公司自有镜像
FROM registry.cn-hangzhou.aliyuncs.com/abroad_images/nginx:1.22.1-alpine3.17
# 复制文件
COPY dist /usr/share/nginx/html

5、在node01主机(10.0.0.21)构建镜像

[root@k8s-node01 demo-receive]# docker build -t registry.cn-hangzhou.aliyuncs.com/abroad_images/demo-ui:v0.0.1 .

# 上传镜像到阿里云仓库
[root@k8s-node01 demo-eureka]# docker push registry.cn-hangzhou.aliyuncs.com/abroad_images/demo-ui:v0.0.1