基于 Docker 的 CI/CD 工具 Drone 所有编译、测试的流程都在 Docker 容器中进行。
开发者只需在项目中包含 .drone.yml 文件,将代码推送到 git 仓库,Drone 就能够自动化的进行编译、测试、发布。
本小节以 GitHub + Drone 来演示 Drone 的工作流程。当然在实际开发过程中,你的代码也许不在 GitHub 托管,那么你可以尝试使用 Gogs + Drone 来进行 CI/CD。
要求
拥有公网 IP、域名 (如果你不满足要求,可以尝试在本地使用 Gogs + Drone)
域名 SSL 证书 (目前国内有很多云服务商提供免费证书)
熟悉
Docker以及Docker Compose熟悉
Git基本命令对
CI/CD有一定了解
新建 GitHub 应用
登录 GitHub,在 https://github.com/settings/applications/new 新建一个应用。

接下来查看这个应用的详情,记录 Client ID 和 Client Secret,之后配置 Drone 会用到。
配置 Drone
我们通过使用 Docker Compose 来启动 Drone,编写 docker-compose.yml 文件。
version: '3'services:drone-server:image: drone/drone:0.8-alpineports:- 443:443# - "${PRO_PUBLIC_IP}:8000:8000"volumes:- drone-data:/var/lib/drone/:rw- ${SSL_PATH}:/etc/certs:rwrestart: alwaysenvironment:- DRONE_SECRET=drone- DRONE_OPEN=false- DRONE_ADMIN=${GITHUB_SERNAME}- DRONE_HOST=${DRONE_HOST}- DRONE_GITHUB=true- DRONE_GITHUB_CLIENT=${DRONE_GITHUB_CLIENT}- DRONE_GITHUB_SECRET=${DRONE_GITHUB_SECRET}- DRONE_SERVER_CERT=/etc/certs/drone.domain.com.crt- DRONE_SERVER_KEY=/etc/certs/drone.domain.com.keydrone-agent:image: drone/agent:0.8-alpinerestart: alwaysdepends_on:- drone-servervolumes:- /var/run/docker.sock:/var/run/docker.sock:rwenvironment:- DRONE_SECRET=drone- DRONE_SERVER=drone-server:9000dns: 114.114.114.114volumes:drone-data:
替换 ${SSL_PATH} 为你网站的 SSL 证书路径。
替换 ${GITHUB_SERNAME} 为你 GitHub 的用户名,该用户将成为 Drone 的管理员。
替换 ${DRONE_HOST} 为你部署 Drone 的域名。
替换 ${DRONE_GITHUB_CLIENT} 为你 GitHub 应用的 Client ID
替换 ${DRONE_GITHUB_SECRET} 为你 GitHub 应用的 Client Secret
注意: 如果你的服务器占用了 443 端口,请配置 Nginx 代理,这里不再赘述。
启动 Drone
$ docker-compose up -d
Drone 关联项目
在 Github 新建一个名为 drone-demo 的仓库。
打开我们已经部署好的 Drone 网站,使用 GitHub 账号登录,在界面中关联刚刚新建的 drone-demo 仓库。
编写项目源代码
在本机初始化一个 git 仓库
$ mkdir drone-demo$ cd drone-demo$ git init$ git remote add origin git@github.com:username/drone-demo.git
这里以一个简单的 Go 程序为例,该程序输出 Hello World!
编写 app.go 文件
package mainimport "fmt"func main(){fmt.Printf("Hello World!");}
编写 .drone.yml 文件
workspace:base: /srv/drone-demopath: .pipeline:build:image: golang:alpine# pull: trueenvironment:- KEY=VALUEsecrets: [key1, key2]commands:- echo $$KEY- pwd- ls- CGO_ENABLED=0 GOOS=linux go build -a -installsuffix cgo -o app .- ./app
workspace 指明 git 源代码克隆的目标路径,本例中 git 源代码将被克隆到 golang 容器中的 /srv/drone-demo 目录中。
pipeline 指明构建所需的 Docker 镜像,环境变量,编译指令等。
现在目录结构如下
.├── .drone.yml└── app.go
推送项目源代码到 GitHub
$ git add .$ git commit -m "test drone ci"$ git push origin master
查看项目构建过程及结果
打开我们部署好的 Drone 网站,即可看到构建结果。

当然我们也可以把构建结果上传到 GitHub,Docker Registry,云服务商提供的对象存储,或者生产环境中。
本书 GitBook 也使用 Drone 进行 CI/CD,具体配置信息请查看本书根目录 .drone.yml 文件。
参考链接
写于 2019年05月08日Docker 1452
如非特别注明,文章皆为原创。
转载请注明出处: https://www.liayal.com/article/5cd276b2c0ab13505eeefad2
记小栈小程序上线啦~搜索【记小栈】或【点击扫码】体验


~ 评论还没有,沙发可以有 O(∩_∩)O~