在开发或生产环境中,经常会搞一套自动化部署方案(俗称一键部署)。比较流行的一种就是Gitlab+Jenkins实现方案,不过这种方案占用内存比较大,没有个8G内存,很难流畅运行,而且部署起来也不快。最近发现一款神器Drone,轻量级CI/DI工具,结合Gogs使用内存占用不到1G,几行脚本就能实现自动化部署!

Drone简介

Drone是一款基于容器技术的持续集成工具,使用简单的YAML配置文件即可完成复杂的自动化构建、测试、部署任务,在Github上已经有22K+Star。

Drone几行脚本搞定自动化部署 - 图1

Gogs安装

使用轻量级的Gogs来搭建Git仓库,这里只是简单说下安装步骤。

  • 首先需要下载Gogs的Docker镜像;
  1. docker pull gogs/gogs
  • 下载完成后在Docker容器中运行Gogs;
  1. docker run -p 10022:22 -p 10080:3000 --name=gogs \
  2. -e TZ="Asia/Shanghai" \
  3. -v /mydata/gogs:/data \
  4. -d gogs/gogs

Drone几行脚本搞定自动化部署 - 图2

  • 然后上传一个测试的项目

Drone安装

接下来安装下Drone,不愧是基于容器的CI/DI工具,使用Docker安装很方便!

  • 首先下载Drone的Server和Runner的镜像;
  1. # Drone的Server
  2. docker pull drone/drone:1
  3. # Drone的Runner
  4. docker pull drone-runner-docker:1
  • 这里有个Server和Runner的概念,先来理解下;
    • Server:为Drone的管理提供了Web页面,用于管理从Git上获取仓库中的流水线任务。
    • Runner:一个单独的守护进程,会轮询Server,获取需要执行的流水线任务,之后执行。
  • 接下来来安装drone-server,使用如下命令即可;
  1. docker run \
  2. -v /mydata/drone:/data \
  3. -e DRONE_AGENTS_ENABLED=true \
  4. -e DRONE_GOGS_SERVER=http://192.168.5.78:10080 \
  5. -e DRONE_RPC_SECRET=dronerpc666 \
  6. -e DRONE_SERVER_HOST=192.168.5.78:3080 \
  7. -e DRONE_SERVER_PROTO=http \
  8. -e DRONE_USER_CREATE=username:macro,admin:true \
  9. -e TZ="Asia/Shanghai" \
  10. -p 3080:80 \
  11. --restart=always \
  12. --detach=true \
  13. --name=drone \
  14. drone/drone:1
  • 这里的配置参数比较多,下面统一解释下; - DRONE_GOGS_SERVER:用于配置Gogs服务地址。 - DRONE_RPC_SECRET:Drone的共享秘钥,用于验证连接到server的rpc连接,server和runner需要提供同样的秘钥。 - DRONE_SERVER_HOST:用于配置Drone server外部可访问的地址。 - DRONE_SERVER_PROTO:用于配置Drone server外部可访问的协议,必须是http或https。 - DRONE_USER_CREATE:创建一个管理员账号,该账号需要在Gogs中注册好。
  • 接下来安装drone-runner-docker,当有需要执行的任务时,会启动临时的容器来执行流水线任务;
  1. docker run -d \
  2. -v /var/run/docker.sock:/var/run/docker.sock \
  3. -e DRONE_RPC_PROTO=http \
  4. -e DRONE_RPC_HOST=192.168.5.78:3080 \
  5. -e DRONE_RPC_SECRET=dronerpc666 \
  6. -e DRONE_RUNNER_CAPACITY=2 \
  7. -e DRONE_RUNNER_NAME=runner-docker \
  8. -e TZ="Asia/Shanghai" \
  9. -p 3000:3000 \
  10. --restart always \
  11. --name runner-docker \
  12. drone/drone-runner-docker:1
  • 这里的配置参数比较多,下面统一解释下。 - DRONE_RPC_PROTO:用于配置连接到Drone server的协议,必须是http或https。 - DRONE_RPC_HOST:用于配置Drone server的访问地址,runner会连接到server获取流水线任务并执行。 - DRONE_RPC_SECRET:用于配置连接到Drone server的共享秘钥。 - DRONE_RUNNER_CAPACITY:限制runner并发执行的流水线任务数量。 - DRONE_RUNNER_NAME:自定义runner的名称。

Drone使用

  • 来访问下Drone的控制台页面,第一次登录需要输入账号密码(在Gogs中注册的账号),访问地址:http://192.168.5.78:3080/

Drone几行脚本搞定自动化部署 - 图3

  • 此时在Gogs中的项目会现在在列表中,如果没有的话可以点下SYNC按钮;

Drone几行脚本搞定自动化部署 - 图4

  • 接下来需要对仓库进行设置,将仓库设置为Trusted(否则Drone创建的容器无法挂载目录到宿主机),最后点击SAVE按钮保存;

Drone几行脚本搞定自动化部署 - 图5

  • 保存成功后会在Gogs中自动配置一个Web钩子,当推送代码到Gogs中去时,会触发这个钩子,然后执行在Drone中的流水线任务;

Drone几行脚本搞定自动化部署 - 图6

最新版Gogs添加Web Hook时可能遇到以下问题

代码仓库—Gogs

  • 拉到最下面,可以发送一个测试推送,推送成功会显示绿色的√;

Drone几行脚本搞定自动化部署 - 图7

  • 此时在Drone中发现其实流水线执行失败了,那是因为在脚本中引用了Secret中的ssh_password

Drone几行脚本搞定自动化部署 - 图8

  • 在仓库的设置中添加一个Secret即可,Secret是专门用来存储密码的,此密码只能被使用或删除,无法被查看;

Drone几行脚本搞定自动化部署 - 图9

  • ACTIVITY FEED中使用RESTART可以重新执行该流水线,发现已经成功执行。

Drone几行脚本搞定自动化部署 - 图10

编写脚本

向Git仓库Push代码时,会自动触发Web钩子,然后Drone就会从Git仓库Clone代码,再通过项目目录下的.drone.yml配置,执行相应的流水线,接下来来看看这个脚本是如何写的。

  • 首先来了解下在.drone.yml中配置的工作流都有哪些操作,看下流程图就知道了;

Drone几行脚本搞定自动化部署 - 图11

  • 再来一个完整的.drone.yml,配上详细的注解,看下就基本懂了!
  1. yamlkind: pipeline # 定义对象类型,还有secret和signature两种类型
  2. type: docker # 定义流水线类型,还有kubernetes、exec、ssh等类型
  3. name: mall-tiny-drone # 定义流水线名称
  4. steps: # 定义流水线执行步骤,这些步骤将顺序执行
  5. - name: package # 流水线名称
  6. image: maven:3-jdk-8 # 定义创建容器的Docker镜像
  7. volumes: # 将容器内目录挂载到宿主机,仓库需要开启Trusted设置
  8. - name: maven-cache
  9. path: /root/.m2 # 将maven下载依赖的目录挂载出来,防止重复下载
  10. - name: maven-build
  11. path: /app/build # 将应用打包好的Jar和执行脚本挂载出来
  12. commands: # 定义在Docker容器中执行的shell命令
  13. - mvn clean package # 应用打包命令
  14. - cp target/mall-tiny-drone-1.0-SNAPSHOT.jar /app/build/mall-tiny-drone-1.0-SNAPSHOT.jar
  15. - cp Dockerfile /app/build/Dockerfile
  16. - cp run.sh /app/build/run.sh
  17. - name: build-start
  18. image: appleboy/drone-ssh # SSH工具镜像
  19. settings:
  20. host: 192.168.5.78 # 远程连接地址
  21. username: root # 远程连接账号
  22. password:
  23. from_secret: ssh_password # 从Secret中读取SSH密码
  24. port: 22 # 远程连接端口
  25. command_timeout: 5m # 远程执行命令超时时间
  26. script:
  27. - cd /mydata/maven/build # 进入宿主机构建目录
  28. - chmod +x run.sh # 更改为可执行脚本
  29. - ./run.sh # 运行脚本打包应用镜像并运行
  30. volumes: # 定义流水线挂载目录,用于共享数据
  31. - name: maven-build
  32. host:
  33. path: /mydata/maven/build # 从宿主机中挂载的目录
  34. - name: maven-cache
  35. host:
  36. path: /mydata/maven/cache
  • run.sh执行脚本可以实现打包应用和运行容器镜像,运行成功效果如下。

Drone几行脚本搞定自动化部署 - 图12

总结

对比Jenkins复杂的图形化界面操作,Drone使用脚本来定义流水线任务无疑更简单、更直观。Drone更加轻量级,内存占用少且响应速度快!自动化部署要啥Jenkins?直接给Git整个CI/DI功能难道不香么?

参考资料

官方文档:https://docs.drone.io/