gitlab-ci自动化构建配置与通知
创建注册Runner
https://docs.gitlab.com/runner/install/docker.html
mkdir /root/gitlab-runner
vim docker-compose.yml
version: '3.3'
services:
gitlab-runner:
container_name: gitlab-runner
restart: always
volumes:
- './config:/etc/gitlab-runner'
- '/var/run/docker.sock:/var/run/docker.sock'
image: 'gitlab/gitlab-runner:latest'
# 运行docker
docker-compose up -d
# 进入docker配置gitlab runner
docker exec -it gitlab-runner bash
# 获取gitlab runner token去注册 注册2次
gitlab-runner register --url <http://192.168.11.202/> --registration-token iBaYd2fPi6YhecwWmu9
# Enter an executor 执行器选择docker 第二次shell
docker shell
# 出现以下内容 注册成功
# Runner registered successfully. Feel free to start it, but if it's running already the config should be automatically reloaded!
这里注册2次runnder是因为 一个CI用 ,一个CD用。 为了编译的环境隔离CI的执行器选择使用docker,CD的时候执行器选择shell通过rasyc统一部署文件。
配置CICD环境变量
SERVER_IP 服务器IP
PORT 服务器SSH端口
DEPLOY_RSA 文件类型变量 存的密钥对 私钥 (提前把rsa密钥对生成好,windows复制到gitlab文本框可能存在编码不对的问题导致ssh验证权限失败)
Java gitlab-ci.yml
stages:
- build-maven
- deploy
variables:
PROJECT_FILE_NAME: "data-big-screen-1.0.jar" # 自定义项目名称变量
PROJECT_DIR: "/home/big-screen/service" # 自定义项目部署服务器的文件夹位置
MAVEN_OPTS: "-Dmaven.repo.local=$CI_PROJECT_DIR/.m2/repository"
maven:
stage: build-maven
image: maven:3-jdk-11
only:
- master
cache:
paths:
- .m2/repository
script:
- mvn clean package -DskipTests=true --settings ./settings.xml
tags:
- ci
artifacts:
expire_in: 6 months # 设置制品在 6 个月后过期
name: "Maven artifacts from $CI_PROJECT_NAME on $CI_COMMIT_REF_SLUG"
paths:
- "target/$PROJECT_FILE_NAME"
job-release:
only:
- master
stage: deploy
dependencies:
- maven
tags:
- cd
- shell
script:
# 以下命令执行前首先要生成RSA公私密钥对 把id_rsa.pub 公钥copy扔到服务器上 ~/.ssh/authorized_keys里面 没有就创建此文件
- mkdir -p ~/.ssh
- cp $DEPLOY_RSA ~/.ssh/id_rsa
- chmod 600 ~/.ssh/id_rsa
- ssh-keyscan -H -p $PORT $SERVER_IP >> ~/.ssh/known_hosts
- chmod 644 ~/.ssh/known_hosts
# 创建项目目录
- ssh -p $PORT root@$SERVER_IP "mkdir -p $PROJECT_DIR"
# 检查rsync是否安装
- ssh -p $PORT root@$SERVER_IP "command -v rsync >/dev/null 2>&1 || { echo 'Installing rsync...'; apt-get update && apt-get install -y rsync; }"
- rsync -avzP -e "ssh -p $PORT" target/$PROJECT_FILE_NAME startup.sh root@$SERVER_IP:$PROJECT_DIR/
# 运行重启脚本
- ssh -p $PORT root@$SERVER_IP "PROJECT_FILE_NAME=$PROJECT_FILE_NAME PROJECT_DIR=$PROJECT_DIR bash $PROJECT_DIR/startup.sh"
Javastartup.sh
启动脚本,放在项目的根目录下
#!/bin/bash
PROJECT_FILE_NAME="${PROJECT_FILE_NAME:-app.jar}" # Default if not set
PROJECT_DIR="${PROJECT_DIR:-/home/service}"
LOG_FILE="$PROJECT_DIR/logs.log"
# Check if the JAR is running and stop it if so
if pgrep -f "$PROJECT_FILE_NAME" > /dev/null; then
echo "$PROJECT_FILE_NAME is currently running. Stopping the application..."
pkill -f "$PROJECT_FILE_NAME"
else
echo "$PROJECT_FILE_NAME is not running."
fi
# Start the new JAR file
nohup java -jar -Xmx2G -Xms2G "$PROJECT_DIR/$PROJECT_FILE_NAME" > "$LOG_FILE" 2>&1 &
echo "Application started."
前端 gitlab-ci.yml
推荐先配置好nginx目录地址然后再执行构建测试,比如我这里ng的文件目录为home/cmgp3/front
stages:
- npm-build
- deploy
variables:
PROJECT_DIR: "/home/cmgp3/front" # 自定义项目部署服务器的文件夹位置
ARTIFACT_NAME: "dist.tar.gz" # 压缩产物
build-node:
image: node:20-alpine
stage: npm-build
only:
- ahswj
tags:
- ops
- ci
cache:
key:
files:
- package-lock.json
paths:
- .npm/
script:
- npm config set registry <https://registry.npmmirror.com>
- npm ci --cache .npm --prefer-offline
- NODE_ENV=production npm run build
- tar -czf $ARTIFACT_NAME -C dist .
artifacts:
expire_in: 1 year
paths:
- $ARTIFACT_NAME
job-release:
stage: deploy
only:
- ahswj
dependencies:
- build-node
tags:
- ops
- cicd
script:
- mkdir -p ~/.ssh
- cp $AHSWJ_22_SSH_RSA ~/.ssh/id_rsa
- chmod 600 ~/.ssh/id_rsa
- ssh-keyscan -H -p $SERVER_IP_PORT $SERVER_IP >> ~/.ssh/known_hosts
- chmod 644 ~/.ssh/known_hosts
- echo "Deploying to $SERVER_IP:$SERVER_IP_PORT"
- ssh -p $SERVER_IP_PORT $SERVER_IP "mkdir -p $PROJECT_DIR &&rm -rf $PROJECT_DIR/* || true"
- rsync -avzP -e "ssh -p $SERVER_IP_PORT" $ARTIFACT_NAME $SERVER_IP:$PROJECT_DIR/
- ssh -p $SERVER_IP_PORT $SERVER_IP "tar -xzf $PROJECT_DIR/$ARTIFACT_NAME -C $PROJECT_DIR"
拓展gitlab ci构建或其他消息通知到企业微信
https://github.com/jahn1612/gitlab-bot
clone 此项目并根据文档编辑compose
version: '3.0'
services:
bot:
build: .
restart: unless-stopped
ports:
- 7001:7001
environment:
- "CONTEXT_PATH=/"
- "WEBHOOK_URL_BENBU=https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=06e2eb3-61ed-4da4-3e7-6704a54acd34"
deploy:
replicas: 1
resources:
reservations:
cpus: '1'
memory: 64M
limits:
cpus: '2'
memory: 256M
update_config:
parallelism: 1
delay: 10s
restart_policy:
condition: on-failure
如以上配置后根据文档填入gitlab的webhook中, _BENBU是推送组 为:benbu
这里的组可以是项目组,或者成员组,具体看企业微信机器人群中的服务范围。
http://192.168.10.44:7001/benbu
2024-12-24 添加向Windows流水线部署
stages:
- npm-build
- deploy
variables:
SFTP_DIR: "/c:/Server/onlineZ2/dist" # SFTP部署服务器的文件夹位置
PROJECT_DIR: "/c/Server/onlineZ2/dist" # SSH路径
ARTIFACT_NAME: "dist.tar.gz" # 压缩产物
build-node:
image: node:20-alpine
stage: npm-build
only:
- main
tags:
- ci
cache:
key:
files:
- pnpm-lock.yaml
paths:
- .pnpm-store
before_script:
- npm config set registry <https://registry.npmmirror.com>
- npm install -g pnpm
- npm install -g vite
- npm config set registry <http://192.168.11.171:9000>
script:
- pnpm install --store .pnpm-store
# - NODE_ENV=production pnpm run build
- pnpm run build
- tar -czf $ARTIFACT_NAME -C dist .
artifacts:
expire_in: 1 year
paths:
- $ARTIFACT_NAME
job-release:
stage: deploy
only:
- main
dependencies:
- build-node
tags:
- cd
script:
- mkdir -p ~/.ssh
- cp $RSA ~/.ssh/id_rsa
- chmod 600 ~/.ssh/id_rsa
- ssh-keyscan -H -p $SERVER_IP_PORT $SERVER_IP >> ~/.ssh/known_hosts
- chmod 644 ~/.ssh/known_hosts
- echo "Deploying to $SERVER_IP:$SERVER_IP_PORT"
- ssh -p $SERVER_IP_PORT $USER@$SERVER_IP "mkdir -p $PROJECT_DIR &&rm -rf $PROJECT_DIR/* || true"
- sftp -P $SERVER_IP_PORT $USER@$SERVER_IP:$SFTP_DIR <<< "put $ARTIFACT_NAME"
- ssh -p $SERVER_IP_PORT $USER@$SERVER_IP "cd $PROJECT_DIR && tar -xzf $ARTIFACT_NAME && rm $ARTIFACT_NAME"