自动化部署实践 - Docker GitAction 阿里云私有化仓库

28岁了

前段时间服务器又过期了,导致原本部署的项目又莫得了,买了个新服务器后,又要重新配置,特别麻烦,秉持不想再折腾的偷懒情结,打算搞一下Docker,将部署的项目一并上传到自己的私有云上,以后换服务器就可以直接docker拉下来一键部署啦。

基本思路

解决问题核心分析了一下,在于开发时保存项目存放至镜像。
具体做法是用到GitAction中监控项目推送的能力,在代码push的时候进行docker镜像的构建,并且上传到阿里云私有仓库。

阿里云仓库

调查过,国外的私有仓库申请很多都是免费的,比如以前的Dockerhub,但是因为天朝的特殊性,这些都用不了了,个人开发者成本比较低的只有阿里云私有仓库可用,这里记录一下怎么申请阿里云私有仓库


步骤一

1.png
2.png

进入阿里云官网搜索容器镜像服务,注册个人版仓库,记住注册密码和命名空间

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;
    }

}
每次push都可以自动部署上传镜像啦
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容