赞
踩
app/
├── container/
│ ├── init.sh
│ ├── nginx.conf.template
├── src/
├── .gitlab-ci.yml
└── deploy.sh
└── Dockerfile
└── Makefile
container目录是放nginx的配置文件,给nginx镜像使用
.gitlab-ci.yml和Makefile是cicd自动发版,适用于测试环境和生产环境
deploy.sh是使用shell手动发版,适用于开发环境
init.sh
主要作用是根据env环境变量替换nginx的反向代理地址
#!/bin/bash
BACKENDURL=$BACKENDURL
export "BACKENDURL"=$BACKENDURL
envsubst '$BACKENDURL' < /etc/nginx/nginx.conf.template > /etc/nginx/nginx.conf && nginx -g 'daemon off;'
nginx.conf.template
user root; events { worker_connections 4096; ## Default: 1024 } http { proxy_connect_timeout 300000; #连接握手时间 proxy_send_timeout 300000; # 设置发送超时时间, proxy_read_timeout 300000; # 设置读取超时时间。 client_max_body_size 100M; include /etc/nginx/mime.types; sendfile on; server { listen 80; listen [::]:80; add_header Access-Control-Allow-Origin *; add_header Access-Control-Allow-Headers X-Requested-With,access-token,Access-Token,Refresh-Token,Accept,Content-Type,User-Agent; add_header Access-Control-Allow-Methods GET,POST,OPTIONS; location / { root /usr/share/nginx/html; index index.html; try_files $uri $uri/ /index.html; } location ^~/api/ { proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-NginX-Proxy true; proxy_pass $BACKENDURL; #后端实际服务器地址 add_header Access-Control-Allow-Origin *; add_header Access-Control-Allow-Headers X-Requested-With,access-token,Access-Token,Refresh-Token,Accept,Content-Type,User-Agent; add_header Access-Control-Allow-Methods GET,POST,OPTIONS; } } }
Dockerfile
镜像内编译打包,因为服务器上可能有多个node项目版本会有兼容问题,直接容器内编译
# 编译打包 FROM node:18-alpine as builder WORKDIR /app COPY package.json . ENV NODE_OPTIONS=--openssl-legacy-provider RUN npm install COPY . . RUN npm run build # 运行应用 FROM nginx:latest COPY --from=builder /app/dist /usr/share/nginx/html COPY container/nginx.conf.template /etc/nginx/nginx.conf.template COPY container/init.sh /init.sh RUN chmod 777 init.sh EXPOSE 80 CMD ["/bin/bash", "/init.sh"]
deploy.sh
人工发版时运行脚本
部署脚本里面打包命令、项目名字、端口、后端地址记得更换
#!/bin/bash set -x function show_help { echo "Usage: $0 [OPTIONS]" echo "Options:" echo " --mode=<mode> Set the mode (local, dev, test, prod)" } # 保存输入的参数 args=("$@") # 使用 shift 命令去除已处理的位置参数 shift # 处理命令行参数 for ((i = 0; i < "${#args[@]}"; i++)); do case "${args[$i]}" in --mode=* | -mode=*) mode="${args[$i]#*=}" ;; --mode | -mode) mode="${args[$((i + 1))]}" ;; --help) show_help exit 0 ;; esac done # 如果 mode 不在合法的模式值中,则输出错误信息 if ! $valid; then echo "mode值只能是:空值 local, dev, test, prod." exit 1 fi # 根据 mode 设置不同的 BACKENDURL 地址 if [ "$mode" == "dev" ]; then BACKENDURL="http://xxxx" elif [ "$mode" == "test" ]; then BACKENDURL="http://xxxx" elif [ "$mode" == "prod" ]; then BACKENDURL="-" else BACKENDURL="http://xxxx" fi name="project" port=8080 version="latest" current_user=$(whoami) echo "当前用户:${current_user}" # 拉代码和打包镜像 git pull # 设置 node_modules 为当前用户 sudo chown -R $current_user:$current_user ./ sudo docker build -f Dockerfile -t $name:$version . # 停止并删除容器 sudo docker stop "$name" sudo docker rm "$name" -f # 启动容器 sudo docker run --restart=always --name $name -p $port:80 -e BACKENDURL="$BACKENDURL" -d $name:$version
运行命令
# 记得先给部署脚本+执行权限
chmod +x ./deploy.sh
./deploy.sh --mode dev
运行截图
项目成功运行
然后浏览器访问:http://xxx.xxx.com:21000
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。