在开发或生产环境中,咱们常常会搞一套自动化部署计划(俗称一键部署)。比拟风行的一种就是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的Serverdocker pull drone/drone:1# Drone的Runnerdocker 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!