返回介绍

Drone

发布于 2019-11-10 06:06:43 字数 5696 浏览 1126 评论 0 收藏 0

基于 DockerCI/CD 工具 Drone 所有编译、测试的流程都在 Docker 容器中进行。

开发者只需在项目中包含 .drone.yml 文件,将代码推送到 git 仓库,Drone 就能够自动化的进行编译、测试、发布。

本小节以 GitHub + Drone 来演示 Drone 的工作流程。当然在实际开发过程中,你的代码也许不在 GitHub 托管,那么你可以尝试使用 Gogs + Drone 来进行 CI/CD

Drone 关联项目

在 Github 新建一个名为 drone-demo 的仓库。

打开我们已经 部署好的 Drone 网站 或者 Drone Cloud,使用 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!n");}

编写 .drone.yml 文件

kind: pipelinetype: dockername: buildsteps:- name: build  image: golang:alpine  pull: if-not-exists # always never  environment:    KEY: VALUE  commands:    - echo $KEY    - pwd    - ls    - CGO_ENABLED=0 GOOS=linux go build -a -installsuffix cgo -o app .    - ./apptrigger:  branch:  - master

现在目录结构如下

.├── .drone.yml└── app.go

推送项目源代码到 GitHub

$ git add .$ git commit -m "test drone ci"$ git push origin master

查看项目构建过程及结果

打开我们部署好的 Drone 网站或者 Drone Cloud,即可看到构建结果。

当然我们也可以把构建结果上传到 GitHub,Docker Registry,云服务商提供的对象存储,或者生产环境中。

本书 GitBook 也使用 Drone 进行 CI/CD,具体配置信息请查看本书根目录 .drone.yml 文件。

参考链接

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文