前段时间服务器又过期了,导致原本部署的项目又莫得了,买了个新服务器后,又要重新配置,特别麻烦,秉持不想再折腾的偷懒情结,打算搞一下Docker,将部署的项目一并上传到自己的私有云上,以后换服务器就可以直接docker拉下来一键部署啦。
基本思路
解决问题核心分析了一下,在于开发时保存项目存放至镜像。
具体做法是用到GitAction中监控项目推送的能力,在代码push的时候进行docker镜像的构建,并且上传到阿里云私有仓库。
阿里云仓库
调查过,国外的私有仓库申请很多都是免费的,比如以前的Dockerhub,但是因为天朝的特殊性,这些都用不了了,个人开发者成本比较低的只有阿里云私有仓库可用,这里记录一下怎么申请阿里云私有仓库
进入阿里云官网搜索容器镜像服务,注册个人版仓库,记住注册密码和命名空间
GitAction
配置项目中的.github/workflows/.yml文件,处理一个自定义的工作流
其中secrets的变量定义在git项目中的Settings - Actions secrets and variables设置
name: Docker Image CI # Actions名称
on: # 执行时机
push:
branches:
- dev
- release
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: checkout # 步骤名字
uses: actions/checkout@master
- name: install
run: npm install
- name: build project
run: npm run build
- name: Build the Docker image
run: |
# 登录阿里云镜像容器
echo "${{ secrets.DOCKER_PASSWORD }}" | docker login -u ${{ secrets.DOCKER_USERNAME }} ${{ secrets.DOCKER_REGISTRY }} --password-stdin
docker build -t jimkingkong-nginx .
docker tag jimkingkong-nginx registry.cn-guangzhou.aliyuncs.com/jimkingkong/nginx:latest
docker push registry.cn-guangzhou.aliyuncs.com/jimkingkong/nginx:latest
- name: ssh docker login
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.SSH_HOST }}
username: ${{ secrets.SSH_USERNAME }}
password: ${{ secrets.SSH_PASSWORD }}
script: |
echo -e "---------登录镜像容器服务--------"
# 登录阿里云镜像容器服务
echo "${{ secrets.DOCKER_PASSWORD }}" | docker login -u ${{ secrets.DOCKER_USERNAME }} ${{ secrets.DOCKER_REGISTRY }} --password-stdin
echo -e "---------停掉镜像--------"
# 停掉容器
docker stop jimkingkong-nginx
echo -e "---------删除本地容器和镜像--------"
# 删除本地容器和镜像
docker rmi jimkingkong-nginx
docker rm jimkingkong-nginx
# 删除本地镜像
docker rmi registry.cn-guangzhou.aliyuncs.com/jimkingkong/nginx:latest
echo -e "---------拉取镜像--------"
# 拉取镜像
docker pull registry.cn-guangzhou.aliyuncs.com/jimkingkong/nginx:latest
echo -e "---------创建容器并运行容器--------"
# -rm: docker会在容器退出时删除与它关联的数据卷
# -d: 后台运行容器,并返回容器ID
# -p: 端口映射,本机端口:容器端口
# --name: 指定容器名称
# 最后一个为镜像名称
docker run -d --name jimkingkong-nginx -p 8080:80 registry.cn-guangzhou.aliyuncs.com/jimkingkong/nginx
echo -e "---------执行完毕--------"
Dockerfile Nginx
Dockerfile会在docker构建镜像中用到,配置nginx.conf写进默认的nginx容器中,将项目代码写进nginx默认的目录中
这里需要记录一下nginx的默认配置文件路径和项目存放路径,会经常用到
/etc/nginx/conf.d/default.conf
/usr/share/nginx/html/
Dockerfile
FROM nginx:latest
ADD nginx.conf /etc/nginx/conf.d/default.conf
COPY dist/ /usr/share/nginx/html/
EXPOSE 80
nginx.conf
server {
listen 80;
server_name _;
gzip on;
gzip_min_length 1k;
gzip_comp_level 6;
gzip_types text/plain text/css text/javascript application/json application/javascript application/x-javascript application/xml;
gzip_vary on;
gzip_disable "MSIE [1-6]\.";
root /usr/share/nginx/html;
include /etc/nginx/mime.types;
location / {
add_header Access-Control-Allow-Origin *;
add_header Access-Control-Allow-Methods 'GET, POST, OPTIONS';
add_header Access-Control-Allow-Headers 'DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization';
try_files $uri $uri/index.html /index.html;
}
}