在开发或生产环境中,咱们常常会搞一套自动化部署计划(俗称一键部署)。比拟风行的一种就是 Gitlab+Jenkins 实现计划,不过这种计划占用内存比拟大,没有个 8G 内存,很难晦涩运行,而且部署起来也不快。最近发现一款神器 Drone,轻量级 CI/DI 工具,联合 Gogs 应用内存占用不到 1G,几行脚本就能实现自动化部署,举荐给大家!
SpringBoot 实战电商我的项目 mall(40k+star)地址:https://github.com/macrozheng/mall
Drone 简介
Drone 是一款基于容器技术的继续集成工具,应用简略的 YAML 配置文件即可实现简单的自动化构建、测试、部署工作,在 Github 上曾经有 22K+Star。
Gogs 装置
咱们将应用轻量级的 Gogs 来搭建 Git 仓库,这里只是简略说下装置步骤,具体应用能够参考《Github 标星 34K+Star,这款开源我的项目助你秒建 Git 服务!》。
- 首先须要下载 Gogs 的 Docker 镜像;
docker pull gogs/gogs
- 下载实现后在 Docker 容器中运行 Gogs;
docker run -p 10022:22 -p 10080:3000 --name=gogs \
-e TZ="Asia/Shanghai" \
-v /mydata/gogs:/data \
-d gogs/gogs
- Gogs 运行胜利后,拜访 Web 页面地址并注册账号:http://192.168.5.78:10080
- 而后将咱们的 SpringBoot 我的项目
mall-tiny-drone
的源码上传上去即可,我的项目地址:https://github.com/macrozheng…
Drone 装置
接下来咱们装置下 Drone,不愧是基于容器的 CI/DI 工具,应用 Docker 装置很不便!
- 首先下载 Drone 的 Server 和 Runner 的镜像;
# Drone 的 Server
docker pull drone/drone:1
# Drone 的 Runner
docker pull drone-runner-docker:1
-
这里有个 Server 和 Runner 的概念,咱们先来了解下;
- Server:为 Drone 的治理提供了 Web 页面,用于治理从 Git 上获取的仓库中的流水线工作。
- Runner:一个独自的守护过程,会轮询 Server,获取须要执行的流水线工作,之后执行。
- 接下来咱们来装置
drone-server
,应用如下命令即可;
docker run \
-v /mydata/drone:/data \
-e DRONE_AGENTS_ENABLED=true \
-e DRONE_GOGS_SERVER=http://192.168.5.78:10080 \
-e DRONE_RPC_SECRET=dronerpc666 \
-e DRONE_SERVER_HOST=192.168.5.78:3080 \
-e DRONE_SERVER_PROTO=http \
-e DRONE_USER_CREATE=username:macro,admin:true \
-e TZ="Asia/Shanghai" \
-p 3080:80 \
--restart=always \
--detach=true \
--name=drone \
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
,当有须要执行的工作时,会启动长期的容器来执行流水线工作;
docker run -d \
-v /var/run/docker.sock:/var/run/docker.sock \
-e DRONE_RPC_PROTO=http \
-e DRONE_RPC_HOST=192.168.5.78:3080 \
-e DRONE_RPC_SECRET=dronerpc666 \
-e DRONE_RUNNER_CAPACITY=2 \
-e DRONE_RUNNER_NAME=runner-docker \
-e TZ="Asia/Shanghai" \
-p 3000:3000 \
--restart always \
--name runner-docker \
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/
- 此时咱们在 Gogs 中的我的项目会当初在列表中,如果没有的话能够点下
SYNC
按钮;
- 接下来咱们须要对仓库进行设置,将仓库设置为
Trusted
(否则 Drone 创立的容器无奈挂载目录到宿主机),最初点击SAVE
按钮保留;
- 保留胜利后会在 Gogs 中主动配置一个 Web 钩子,当咱们推送代码到 Gogs 中去时,会触发这个钩子,而后执行在 Drone 中的流水线工作;
- 拉到最上面,咱们能够发送一个测试推送,推送胜利会显示绿色的√;
- 此时咱们在 Drone 中发现其实流水线执行失败了,那是因为咱们在脚本中援用了 Secret 中的
ssh_password
;
- 在仓库的设置中增加一个 Secret 即可,Secret 是专门用来存储明码的,此明码只能被应用或删除,无奈被查看;
- 在
ACTIVITY FEED
中应用RESTART
能够从新执行该流水线,发现曾经胜利执行。
编写脚本
当咱们向 Git 仓库 Push 代码时,会主动触发 Web 钩子,而后 Drone 就会从 Git 仓库 Clone 代码,再通过我的项目目录下的
.drone.yml
配置,执行相应的流水线,接下来咱们来看看这个脚本是如何写的。
- 首先咱们来理解下在
.drone.yml
中配置的工作流都有哪些操作,看下流程图就晓得了;
- 再来一个残缺的
.drone.yml
,配上具体的注解,看下就根本懂了!
kind: pipeline # 定义对象类型,还有 secret 和 signature 两种类型
type: docker # 定义流水线类型,还有 kubernetes、exec、ssh 等类型
name: mall-tiny-drone # 定义流水线名称
steps: # 定义流水线执行步骤,这些步骤将程序执行
- name: package # 流水线名称
image: maven:3-jdk-8 # 定义创立容器的 Docker 镜像
volumes: # 将容器内目录挂载到宿主机,仓库须要开启 Trusted 设置
- name: maven-cache
path: /root/.m2 # 将 maven 下载依赖的目录挂载进去,避免反复下载
- name: maven-build
path: /app/build # 将利用打包好的 Jar 和执行脚本挂载进去
commands: # 定义在 Docker 容器中执行的 shell 命令
- mvn clean package # 利用打包命令
- cp target/mall-tiny-drone-1.0-SNAPSHOT.jar /app/build/mall-tiny-drone-1.0-SNAPSHOT.jar
- cp Dockerfile /app/build/Dockerfile
- cp run.sh /app/build/run.sh
- name: build-start
image: appleboy/drone-ssh # SSH 工具镜像
settings:
host: 192.168.5.78 # 近程连贯地址
username: root # 近程连贯账号
password:
from_secret: ssh_password # 从 Secret 中读取 SSH 明码
port: 22 # 近程连贯端口
command_timeout: 5m # 近程执行命令超时工夫
script:
- cd /mydata/maven/build # 进入宿主机构建目录
- chmod +x run.sh # 更改为可执行脚本
- ./run.sh # 运行脚本打包利用镜像并运行
volumes: # 定义流水线挂载目录,用于共享数据
- name: maven-build
host:
path: /mydata/maven/build # 从宿主机中挂载的目录
- name: maven-cache
host:
path: /mydata/maven/cache
run.sh
执行脚本能够实现打包利用和运行容器镜像,之前讲过这里就不再赘述了,具体能够参考《我罕用的自动化部署技巧,贼好用,举荐给大家!》,运行胜利成果如下。
总结
比照 Jenkins 简单的图形化界面操作,Drone 应用脚本来定义流水线工作无疑更简略、更直观。Drone 更加轻量级,内存占用少且响应速度快!自动化部署要啥 Jenkins?间接给 Git 整个 CI/DI 性能难道不香么?
参考资料
- 官网文档:https://docs.drone.io/
- 联合 Maven 应用:https://docs.drone.io/pipelin…
- 联合 SSH 应用:http://plugins.drone.io/apple…
- 将容器目录挂载到宿主机:https://docs.drone.io/pipelin…
我的项目源码地址
https://github.com/macrozheng…
本文 GitHub https://github.com/macrozheng/mall-learning 曾经收录,欢送大家 Star!