前端自动化部署【四】:docker构建发布

  • 基本的Linux、docker操作不再详细介绍
  • 水平有限,如有不足见谅

1. vscode打开前端项目,在根目录创建Dockerfile

js 复制代码
# build stage
# 开启一个node:18容器命名production-stage
FROM node:18 as build-stage
# 创建一个工作目录
WORKDIR /app
# 拷贝项目内容到app目录
COPY . .
# 安装依赖
RUN npm install --registry=https://registry.npm.taobao.org
# 构建dist
RUN npm run build

# production stage
# 开启一个nginx容器命名production-stage
FROM nginx as production-stage
# 将打包的文件拷贝到nginx对应静态文件目录
COPY --from=build-stage /app/dist /usr/share/nginx/html
# 暴露端口80
EXPOSE 80
# 启动nginx
CMD ["nginx", "-g", "daemon off;"]

2.添加.dockerignore文件,这样执行COPY命令会忽略没用的问价比如node_modules等

shell 复制代码
# Dependency directory
# https://www.npmjs.org/doc/misc/npm-faq.html#should-i-check-my-node_modules-folder-into-git
node_modules
.DS_Store
dist

# node-waf configuration
.lock-wscript

# Compiled binary addons (http://nodejs.org/api/addons.html)
build/Release
.dockerignore
Dockerfile
*docker-compose*

# Logs
logs
*.log

# Runtime data
.idea
.vscode
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw*
pids
*.pid
*.seed
.git
.hg
.svn

3.接着配置shell命令所需要的参数,一共四个:容器名称、容器端口、镜像名字、镜像版本

4.

bash 复制代码
#!/bin/bash
CONTAINER=${container_name}
PORT=${port}
# CONTAINER是否存在,若存在,若不存在,说明首次发版
if [[ -n $(docker ps -q -f "name=^${CONTAINER}$") ]];then
    #说明是更新发版,需要停止容器,删除容器
    echo "container exist"
    docker stop $CONTAINER
    docker rm $CONTAINER
else
	echo "container not exist"
fi
#构建镜像
 docker build --no-cache -t ${image_name}:${tag} .
#启动镜像生成容器
 docker run -d --name $CONTAINER -p $PORT:80 ${image_name}:${tag}

5.

6. 回到浏览器访问阿里云公网IP:1234,已经可以看到页面了

注意nginx内部默认端口是80,我们在DOCKERFILE里面的配置1234,然后在shell里面启动命令式docker run -d --name $CONTAINER -p $PORT:80 ${image_name}:${tag},也就是服务器端口1234指向了nginx内部的80,

7. 初次发版(访问失败就去Jenkins所在的服务器安全组添加1234,前面有讲)

8.最后一步,回到vscode,随便修改内容,然后push代码,等待Jenkins构建完成 ,刷新页面

9.累死累活,终于看见页面,完结撒花🌺

相关推荐
漂流瓶jz7 小时前
Webpack如何实现万物皆可import?loader的使用/配置/手写实践
前端·javascript·webpack
ZC跨境爬虫7 小时前
跟着 MDN 学CSS day_41:显式轨道、隐式网格与区域命名放置
前端·javascript·css·ui·交互
修己xj8 小时前
告别手动存图!这款叫 Fatkun 的浏览器插件,简直是素材收集神器
前端
袋鼠云数栈9 小时前
从前端到基础设施,ACOS 如何打通企业全链路可观测
运维·前端·人工智能·数据治理·数据智能
AskHarries9 小时前
系统提示词、开发者指令和用户输入的优先级
java·前端·数据库
Moment9 小时前
长上下文会最终杀死 Rag 吗?
前端·javascript·后端
gsls2008089 小时前
JVM 堆内存参数 & Docker 容器适配,一次讲清楚
jvm·docker·容器
qcx239 小时前
【系统学AI】25 论文导读 ①:两篇改变 AI 的开山之作——Attention Is All You Need & ReAct
前端·人工智能·react.js·transformer
kyriewen10 小时前
大文件上传最全指南:分片、断点续传、秒传,一篇就够了
前端·javascript·面试
Lumbrologist11 小时前
【零基础部署】Docker 部署 AutoGen 多 Agent 对话框架保姆级教程
运维·docker·容器