需求
通过 gitlab-ci 实现文件的自动部署
实现方案
文档托管在 GitLab 上, 每次代码更新, 会自动出发 gitlab-ci 构建
在构建脚本中, 通过 SSH 登录远程服务器执行 Git 拉取文档的命令
实现过程
- 首先需要生产服务器上生成 SSH 证书,并且将公钥添加到 GitLab 上, 以便于该用于可以拉取代码
- 在
CI/CD Piplines
中设置Secret Variables
, 包括DEPLOY_SERVER
和SSH_PRIVATE_KEY环境变量(环境变量可自由编写)
- 编写
.gitlab-ci.yml
文件, 注入密钥, 通过ssh
执行远程命令
其中 SSH_PRIVATE_KEY 的内容是编译方服务器上的私钥, DEPLOY_SERVER 是生产服务器地址
完整代码
stages:
- test
- build
- release
test_job:
stage: test
script:
# 预先装 ssh-agent
- 'which ssh-agent || ( apk update && apk add openssh-client)'
# 启动服务
- eval $(ssh-agent -s)
# 将私钥写入deploy.key 文件
- echo "$SSH_PRIVATE_KEY" >