Merge branch 'develop' of git.pogorockgames.com:mango-games/server/game into develop
This commit is contained in:
commit
f3b7211913
|
@ -2,14 +2,13 @@ stages:
|
||||||
- lock
|
- lock
|
||||||
- build
|
- build
|
||||||
- save
|
- save
|
||||||
- sync
|
|
||||||
- unlock
|
- unlock
|
||||||
|
|
||||||
variables:
|
variables:
|
||||||
ProjectPath: "mongo.games.com/game" # 项目相对于GOPATH的路径
|
GOPATH: "/home/gopath"
|
||||||
|
GoServerSrcPath: "mongo.games.com/goserver" # 项目相对于GOPATH/src的路径
|
||||||
BetaBinPath: "/home/game/" # beta环境部署路径
|
BetaBinPath: "/home/game/" # beta环境部署路径
|
||||||
DevelopBinPath: "/home/game/" # develop环境部署路径
|
DevelopBinPath: "/home/game/" # develop环境部署路径
|
||||||
GOPROXY: "https://goproxy.cn,direct"
|
|
||||||
|
|
||||||
default:
|
default:
|
||||||
tags:
|
tags:
|
||||||
|
@ -26,12 +25,12 @@ lock_job:
|
||||||
stage: lock
|
stage: lock
|
||||||
script:
|
script:
|
||||||
- |
|
- |
|
||||||
if [ -f /tmp/ci_lock ]; then
|
if [ -f /tmp/ci_lock_$CI_COMMIT_REF_NAME ]; then
|
||||||
echo "流水线已在运行,等待..."
|
echo "流水线($CI_COMMIT_REF_NAME)已在运行,等待..."
|
||||||
exit 1
|
exit 1
|
||||||
else
|
else
|
||||||
touch /tmp/ci_lock
|
touch /tmp/ci_lock_$CI_COMMIT_REF_NAME
|
||||||
echo "获得锁定,开始流水线。"
|
echo "获得锁定,开始流水线($CI_COMMIT_REF_NAME)。"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
build-job:
|
build-job:
|
||||||
|
@ -42,19 +41,18 @@ build-job:
|
||||||
script:
|
script:
|
||||||
- git checkout $CI_COMMIT_REF_NAME
|
- git checkout $CI_COMMIT_REF_NAME
|
||||||
- git pull origin $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
|
- if [ ! -z "$(git status --porcelain go.mod go.sum)" ]; then
|
||||||
GOMODTIDY=1;
|
GOMODTIDY=1;
|
||||||
fi
|
fi
|
||||||
# 拷贝到GOPATH
|
|
||||||
- echo '拷贝到GOPATH'
|
|
||||||
- rsync -rvc --no-perms --delete ./* $GOPATH/src/$ProjectPath
|
|
||||||
# 进入项目目录
|
|
||||||
- cd $GOPATH/src/$ProjectPath
|
|
||||||
# 编译
|
# 编译
|
||||||
- echo '编译'
|
- echo '编译'
|
||||||
- if [ "$GOMODTIDY" == 1 ]; then
|
- if [ "$GOMODTIDY" == 1 ]; then
|
||||||
go mod tidy;
|
go mod tidy;
|
||||||
go mod download;
|
|
||||||
fi
|
fi
|
||||||
- |
|
- |
|
||||||
while IFS= read -r line || [[ -n $line ]]
|
while IFS= read -r line || [[ -n $line ]]
|
||||||
|
@ -71,7 +69,6 @@ save-job:
|
||||||
- develop
|
- develop
|
||||||
- release
|
- release
|
||||||
script:
|
script:
|
||||||
- cd $GOPATH/src/$ProjectPath
|
|
||||||
# 拷贝文件
|
# 拷贝文件
|
||||||
- echo '拷贝文件'
|
- echo '拷贝文件'
|
||||||
- rm -rf ./temp
|
- rm -rf ./temp
|
||||||
|
@ -95,49 +92,10 @@ save-job:
|
||||||
mv ./$line/$line ./temp/$line
|
mv ./$line/$line ./temp/$line
|
||||||
done < ./programs.txt
|
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:
|
unlock_job:
|
||||||
stage: unlock
|
stage: unlock
|
||||||
script:
|
script:
|
||||||
- rm -f /tmp/ci_lock
|
- rm -f /tmp/ci_lock_$CI_COMMIT_REF_NAME
|
||||||
- echo "释放锁定,流水线结束。"
|
- echo "释放锁定,流水线结束(/$CI_COMMIT_REF_NAME)。"
|
||||||
when: always
|
when: always
|
Loading…
Reference in New Issue