Gitlab

阅读该链接获取具体的gitlab与gitlab-runner装置
Docker 装置与装备 Gitlab

装置Gitlab

mkdir -p /data/gitlab/config
mkdir -p /data/gitlab/logs
mkdir -p /data/gitlab/data
docker run -d \
-h <host> \
-p 443:443 -p <port>:80 -p 2222:22 \
-e TZ=Asia/Shanghai \
--shm-size 256m \
--name gitlab \
--restart always \
-v /data/gitlab/config:/etc/gitlab \
-v /data/gitlab/logs:/var/log/gitlab \
-v /data/gitlab/data:/var/opt/gitlab \
gitlab/gitlab-ce:latest

Gitlab-Runner

gitlab需求runner, 装置

mkdir -p /data/gitlab-runner5/config
docker run \
-d \
--name gitlab-runner \
--restart always \
-v /data/gitlab-runner/config:/etc/gitlab-runner \
-v /var/run/docker.sock:/var/run/docker.sock \
gitlab/gitlab-runner:latest

注册Gitlab-Runner

注册一个或多个gitlab-runner对项目进行流水线作业

docker run \
-it \
-v /data/gitlab-runner/config:/etc/gitlab-runner \
gitlab/gitlab-runner:latest register

部署

前端

Cache

key:

  1. 缓存node_modules,下一次的流水线无需全部装置一次(可优化点)
  2. 保存build打包之后的dist目录,给下一个Job运用
init Job部分

script脚本解释:

  1. 运用node:14-alpine容器对前端项目进行装置
  2. (可选)项目运用pnpm包管理器, 所以大局装置pnpm运用
  3. 打包项目
deploy Job部分
  • image:
    rockylinux: Ceontos的代替发行版

  • script脚本解释:

  1. 生成索引缓存索引供给查找装置速度
  2. 下载sshpass,openssh-clients用于SSH登录服务器
  3. 进入打包后的dist目录,对里边一切文件进行紧缩,并排除node_modules,紧缩后名文件为dist.tar.gz
  4. 设置出产服务器的暗码的变量为SSHPASS,从gitlab的环境变量获取
  5. 发送dist.tar.gz文件至出产服务器的nginx路径
  6. 进入到出产服务器的nginx路径, 对dist.tar.gz文件进行解压, 解压完成后删去dist.tar.gz文件
stages:
  - init
  - deploy
cache:
  key: frond-end
  paths:
    - node_modules
    - dist
job_init:
  stage: init
  image: node:14-alpine
  tags:
    - cd2
  script:
    - npm install pnpm -g
    - pnpm install
    - pnpm build
  only:
    - main
  artifacts:
    paths:
      - build/
job_deploy:
  stage: deploy
  image: rockylinux
  only:
    - main
  tags:
    - cd2
  script:
    - yum makecache
    - yum install -y sshpass  openssh-clients
    - cd dist && tar -czvf dist.tar.gz --exclude=node_modules ./*
    - export SSHPASS="$PASSWORD"
    - sshpass -e scp -o stricthostkeychecking=no ./dist.tar.gz root@'192.168.0.158':/home/nginx/html/web/
    - sshpass -e ssh -o stricthostkeychecking=no root@192.168.0.158 'tar -xzvf /home/nginx/html/web/dist.tar.gz -C /home/nginx/html/web && rm -rf /home/nginx/html/web/dist.tar.gz'

Golang

stages:
  - build
  - deploy
# 设置缓存,设置需求保存的产品 下一个Job不会保存前一个Job的资源
cache:
  key: go-build # 假如设置多个Key, 有相同的key会覆盖
  paths:
    - app # 需求保存的产品
# 打包Golang项目为二进制文件
job_build:
  stage: build
  image: golang # 利用Golang容器进行打包Golang项目
  tags:
    - golang
  script:
    - go env -w GOPROXY=https://goproxy.cn,direct
    - go get
    - go build -o app
    - chmod +x app
job_deploy:
  stage: deploy
  image: rockylinux
  only:
    - main
  tags:
    - golang
  script:
    - yum makecache # 生成索引缓存索引供给查找装置速度
    - yum install -y sshpass  openssh-clients
    - export SSHPASS="$PASSWORD" # 暗码,从gitlab的环境变量设置与获取
    - sshpass -e scp -o stricthostkeychecking=no ./dir.sh root@192.168.0.158:/ # sshpass -e 从环境变量获取暗码 scp -o stricthostkeychecking=no 疏忽RSA Key查看信息
    - sshpass -e ssh -o stricthostkeychecking=no root@'192.168.0.158' 'cd / && bash dir.sh && rm -rf dir.sh'
    - sshpass -e scp -o stricthostkeychecking=no ./app ./Dockerfile ./deploy.sh root@192.168.0.158:/home/temp # sshpass -e 从环境变量获取暗码 scp -o stricthostkeychecking=no 疏忽RSA Key查看信息
    - sshpass -e ssh -o stricthostkeychecking=no root@'192.168.0.158' 'cd /home/temp && bash deploy.sh' #履行 sh

dir.sh 创立临时目录

#!/bin/bash
# 需求创立的目录
dir=/home/temp
# 列出该目录一切文件
res=$(ls -A $dir)
# 查看该目录是否有文件, 没有则创立
if [ -z "$res" ]; then
  mkdir -p /home/temp
fi

deploy.sh

#!/bin/bash
# 检测goimage(.gitlab-ci.yml供给的golang打包后的二进制文件的名称)是否已在运转, 假如已在运转则中止该容器
# docker ps 列出Docker容器列表
# grep goimage 查找docker ps 列出Docker容器列表有没有goimage这个字串
# awk '{print $12}' 从docker ps 列出Docker容器列表的第12列(容器名)
# docker stop goimage 中止运转goimage容器
if [ $(docker ps | grep goimage | awk '{print $12}') ]; then docker stop goimage; fi
# 假如goimage容器存在 则删去该容器
# docker ps -a 列出全部容器
# docker ps -q 静默模式,只列出容器编号
# docker ps -aq 列出全部容器编号
# --filter name=goimage 过滤出容器名称为goimage的容器
# docker rm -f goimage 删去goimage容器
if [ $(docker ps -aq --filter name=goimage) ]; then
  docker rm -f goimage
fi
# docker images 列出一切镜像
# docker rmi -f 强制删去
# docker rmi -f goimage 强制删去goimage镜像
if [ $(docker images | grep goimage | awk '{print $1}') ]; then docker rmi -f goimage; fi
# 在本目录打包一个镜像姓名及标签为goimage的二进制文件可运转的Docker镜像
# docker build --tag 镜像的姓名及标签,通常 name:tag 或许 name 格局;能够在一次构建中为一个镜像设置多个标签。
docker build --tag goimage .
# docker run 运转
# -d 后台运转容器,并回来容器ID
# -p 映射主机与容器的端口
# --name 容器名称
docker run -d -p 4000:4000 --name goimage goimage
# 删去上传的文件
rm -rf /home/temp