diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index e2f6f58..cdb4811 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -2,14 +2,13 @@ stages: - lock - build - save - - sync - unlock variables: - ProjectPath: "mongo.games.com/game" # 项目相对于GOPATH的路径 + GOPATH: "/home/gopath" + GoServerSrcPath: "mongo.games.com/goserver" # 项目相对于GOPATH/src的路径 BetaBinPath: "/home/game/" # beta环境部署路径 DevelopBinPath: "/home/game/" # develop环境部署路径 - GOPROXY: "https://goproxy.cn,direct" default: tags: @@ -26,12 +25,12 @@ lock_job: stage: lock script: - | - if [ -f /tmp/ci_lock ]; then - echo "流水线已在运行,等待..." + if [ -f /tmp/ci_lock_$CI_COMMIT_REF_NAME ]; then + echo "流水线($CI_COMMIT_REF_NAME)已在运行,等待..." exit 1 else - touch /tmp/ci_lock - echo "获得锁定,开始流水线。" + touch /tmp/ci_lock_$CI_COMMIT_REF_NAME + echo "获得锁定,开始流水线($CI_COMMIT_REF_NAME)。" fi build-job: @@ -42,19 +41,18 @@ build-job: script: - git checkout $CI_COMMIT_REF_NAME - git pull origin $CI_COMMIT_REF_NAME + + # 替换 go.mod 中的 ../goserver + - sed -i "s|mongo.games.com/goserver => .*|mongo.games.com/goserver => $GOPATH/src/$GoServerSrcPath|" go.mod + - if [ ! -z "$(git status --porcelain go.mod go.sum)" ]; then GOMODTIDY=1; fi - # 拷贝到GOPATH - - echo '拷贝到GOPATH' - - rsync -rvc --no-perms --delete ./* $GOPATH/src/$ProjectPath - # 进入项目目录 - - cd $GOPATH/src/$ProjectPath + # 编译 - echo '编译' - if [ "$GOMODTIDY" == 1 ]; then go mod tidy; - go mod download; fi - | while IFS= read -r line || [[ -n $line ]] @@ -71,7 +69,6 @@ save-job: - develop - release script: - - cd $GOPATH/src/$ProjectPath # 拷贝文件 - echo '拷贝文件' - rm -rf ./temp @@ -95,49 +92,10 @@ save-job: mv ./$line/$line ./temp/$line done < ./programs.txt -sync_job: - stage: sync - only: - - develop - - release - script: - - cd $GOPATH/src/$ProjectPath - - if [ "$CI_COMMIT_BRANCH" == "develop" ]; then - SSH_PRIVATE_KEY="$SSH_PRIVATE_KEY_DEVELOP"; - REMOTE_HOST="$REMOTE_HOST_DEVELOP"; - REMOTE_USER="$REMOTE_USER_DEVELOP"; - ServerName="develop"; - BinPath="$DevelopBinPath"; - elif [ "$CI_COMMIT_BRANCH" == "release" ]; then - SSH_PRIVATE_KEY="$SSH_PRIVATE_KEY_BETA"; - REMOTE_HOST="$REMOTE_HOST_BETA"; - REMOTE_USER="$REMOTE_USER_BETA"; - ServerName="beta"; - BinPath="$BetaBinPath"; - else - echo "不支持的分支"; - exit 1; - fi - - # 设置 .ssh 目录并写入 SSH 私钥 - - echo "设置 SSH keys..." - - mkdir -p ~/.ssh - - echo "$SSH_PRIVATE_KEY" | tr -d '\r' > ~/.ssh/id_rsa - - chmod 600 ~/.ssh/id_rsa - - ssh-keyscan -H "$REMOTE_HOST" >> ~/.ssh/known_hosts - - # 使用 rsync 将文件同步到远程服务器 - - echo "同步到服务器" - - echo "Deploying to remote server using rsync... $BinPath" - - rsync -rvz --delete ./temp/ $REMOTE_USER@$REMOTE_HOST:$BinPath - - # 触发部署 - - "curl -X POST --fail -F token=$SERVER_CI_TOKEN -F ref=release -F variables[ServerName]=$ServerName https://git.pogorockgames.com/api/v4/projects/31/trigger/pipeline" - # 解锁作业,释放锁定 unlock_job: stage: unlock script: - - rm -f /tmp/ci_lock - - echo "释放锁定,流水线结束。" + - rm -f /tmp/ci_lock_$CI_COMMIT_REF_NAME + - echo "释放锁定,流水线结束(/$CI_COMMIT_REF_NAME)。" when: always \ No newline at end of file