如何在linux 上配置持续集成服务 - Drone ============================================================== 如果你对一次又一次的克隆、构建、测试和部署代码感到厌倦了,可以考虑一下持续集成。持续集成也就是CI,是软件工程的像我们一样的频繁提交的代码库,构建、测试和部署的实践。CI 帮助我们快速的集成新代码到已有的代码基线。如果这个过程是自动化进行的,那么就会提高开发的速度,因为这可以减少开发人员手工构建和测试的时间。[Drone][1] 是一个免费的开源项目,用来提供一个非常棒的持续集成服务的环境,采用了Apache 2.0 协议。它已经集成近很多代码库提供商,比如Github、Bitbucket 以及Google COde,并且它可以从代码库提取代码,使我们可以编译多种语言,包括PHP, Node, Ruby, Go, Dart, Python, C/C++, JAVA 等等。它是如此一个强大的平台是因为它每次构建都使用了容器和docker 技术,这让用户可以在保证隔离的条件下完全控制他们自己的构建环境。 ### 1. 安装 Docker ### 首先,我们要安装docker,因为这是Drone 的工作流的最关键的元素。Drone 合理的利用了docker 来构建和测试应用。容器技术提高了应用部署的效率。要安装docker ,我们需要在不同的linux 发行版本运行下面对应的命令,我们这里会说明Ubuntu 14.04 和CentOS 7 两个版本。 #### Ubuntu #### 要在Ubuntu 上安装Docker ,我们只需要运行下面的命令。 # apt-get update # apt-get install docker.io 安装之后我们需要使用`service` 命令重启docker 引擎。 # service docker restart 然后我们让docker 在系统启动时自动启动。 # update-rc.d docker defaults Adding system startup for /etc/init.d/docker ... /etc/rc0.d/K20docker -> ../init.d/docker /etc/rc1.d/K20docker -> ../init.d/docker /etc/rc6.d/K20docker -> ../init.d/docker /etc/rc2.d/S20docker -> ../init.d/docker /etc/rc3.d/S20docker -> ../init.d/docker /etc/rc4.d/S20docker -> ../init.d/docker /etc/rc5.d/S20docker -> ../init.d/docker #### CentOS #### 第一,我们要更新机器上已经安装的软件包。我们可以使用下面的命令。 # sudo yum update 要在centos 上安装docker,我们可以简单的运行下面的命令。 # curl -sSL https://get.docker.com/ | sh 安装好docker 引擎之后我么只需要简单实用下面的`systemd` 命令启动docker,因为centos 7 的默认init 系统是systemd。 # systemctl start docker 然后我们要让docker 在系统启动时自动启动。 # systemctl enable docker ln -s '/usr/lib/systemd/system/docker.service' '/etc/systemd/system/multi-user.target.wants/docker.service' ### 2. 安装 SQlite 驱动 ### Drone 默认使用SQLite3 数据库服务器来保存数据和信息。它会在/var/lib/drone/ 自动创建名为drone.sqlite 的数据库来处理数据库模式的创建和迁移。要安装SQLite3 我们要完成以下几步。 #### Ubuntu 14.04 #### 因为SQLite3 存在于Ubuntu 14.04 的默认软件库,我们只需要简单的使用apt 命令安装它。 # apt-get install libsqlite3-dev #### CentOS 7 #### 要在Centos 7 上安装选哟使用下面的yum 命令。 # yum install sqlite-devel ### 3. 安装 Drone ### 最后,我们安装好依赖的软件,我们现在更进一步的接近安装Drone。在这一步里我们值简单的从官方链接下载对应的二进制软件包,然后使用默认软件包管理器安装Drone。 #### Ubuntu #### 我们将使用wget 从官方的[Debian 文件下载链接][2]下载drone 的debian 软件包。下面就是下载命令。 # wget downloads.drone.io/master/drone.deb Resolving downloads.drone.io (downloads.drone.io)... 54.231.48.98 Connecting to downloads.drone.io (downloads.drone.io)|54.231.48.98|:80... connected. HTTP request sent, awaiting response... 200 OK Length: 7722384 (7.4M) [application/x-debian-package] Saving to: 'drone.deb' 100%[======================================>] 7,722,384 1.38MB/s in 17s 2015-11-06 14:09:28 (456 KB/s) - 'drone.deb' saved [7722384/7722384] 下载好之后,我们将使用dpkg 软件包管理器安装它。 # dpkg -i drone.deb Selecting previously unselected package drone. (Reading database ... 28077 files and directories currently installed.) Preparing to unpack drone.deb ... Unpacking drone (0.3.0-alpha-1442513246) ... Setting up drone (0.3.0-alpha-1442513246) ... Your system ubuntu 14: using upstart to control Drone drone start/running, process 9512 #### CentOS #### 在CentOS 机器上我们要使用wget 命令从[下载链接][3]下载RPM 包。 # wget downloads.drone.io/master/drone.rpm --2015-11-06 11:06:45-- http://downloads.drone.io/master/drone.rpm Resolving downloads.drone.io (downloads.drone.io)... 54.231.114.18 Connecting to downloads.drone.io (downloads.drone.io)|54.231.114.18|:80... connected. HTTP request sent, awaiting response... 200 OK Length: 7763311 (7.4M) [application/x-redhat-package-manager] Saving to: ‘drone.rpm’ 100%[======================================>] 7,763,311 1.18MB/s in 20s 2015-11-06 11:07:06 (374 KB/s) - ‘drone.rpm’ saved [7763311/7763311] 然后我们使用yum 安装rpm 包。 # yum localinstall drone.rpm ### 4. 配置端口 ### 安装完成之后,我们要使它工作要先进行配置。drone 的配置文件在**/etc/drone/drone.toml** 。默认情况下drone 的web 接口使用的是80,而这也是http 默认的端口,如果我们要下面所示的修改配置文件里server 块对应的值。 [server] port=":80" ### 5. 集成 Github ### 为了运行Drone 我们必须设置最少一个和GitHub、GitHub 企业版,Gitlab,Gogs,Bitbucket 关联的集成点。在本文里我们只集成了github,但是如果哦我们要集成其他的我们可以在配置文件做修改。为了集成github 我们需要在[github setting] 创建一个新的应用。 ![Registering App Github](http://blog.linoxide.com/wp-content/uploads/2015/11/registering-app-github.png) 要创建一个应用,我们需要在`New Application` 页面点击`Register`,然后如下所示填表。 ![Registering OAuth app github](http://blog.linoxide.com/wp-content/uploads/2015/11/registering-OAuth-app-github.png) 我们应该保证在应用的配置项里设置了**授权了的回调链接**,链接看起来像`http://drone.linoxide.com/api/auth/github.com`。然后我们点击注册应用。所有都做好之后我们会看到我们需要在我们的Drone 配置文件里配置的客户端ID 和客户端密钥。 ![Client ID and Secret Token](http://blog.linoxide.com/wp-content/uploads/2015/11/client-id-secret-token.png) 在这些都完成之后我们需要使用文本编辑器编辑drone 配置文件,比如使用下面的命令。 # nano /etc/drone/drone.toml 然后我们会在drone 的配置文件里面找到`[github]` 部分,紧接着的是下面所示的配置内容 [github] client="3dd44b969709c518603c" secret="4ee261abdb431bdc5e96b19cc3c498403853632a" # orgs=[] # open=false ![Configuring Github Drone](http://blog.linoxide.com/wp-content/uploads/2015/11/configuring-github-drone-e1446835124465.png) ### 6. 配置 SMTP 服务器 ### 如果我们想让drone 使用email 发送通知,那么我们需要在SMTP 配置里面设置我们的SMTP 服务器。如果我们已经有了一个SMTP 服务,那就只需要简单的使用它的配置文件就行了,但是因为我们没有一个SMTP 服务器,我们需要安装一个MTA 比如Postfix,然后在drone 配置文件里配置好SMTP。 #### Ubuntu #### 在ubuntu 里使用下面的apt 命令安装postfix。 # apt-get install postfix #### CentOS #### 在CentOS 里使用下面的yum 命令安装postfix。 # yum install postfix 安装好之后,我们需要编辑我们的postfix 配置文件。 # nano /etc/postfix/main.cf 然后我们要把myhostname 的值替换为我们自己的FQDN,比如drone.linoxide.com。 myhostname = drone.linoxide.com 现在开始配置drone 配置文件里的SMTP 部分。 # nano /etc/drone/drone.toml 找到`[smtp]` 部分补充上下面的内容。 [smtp] host = "drone.linoxide.com" port = "587" from = "root@drone.linoxide.com" user = "root" pass = "password" ![Configuring SMTP Drone](http://blog.linoxide.com/wp-content/uploads/2015/11/configuring-smtp-drone.png) 注意:这里的**user** 和 **pass** 参数强烈推荐一定要改成一个用户的配置。 ### 7. 配置 Worker ### 如我们所知的drone 利用了docker 完成构建、测试任务,我们需要把docker 配置为drone 的worker。要完成这些需要修改drone 配置文件里的`[worker]` 部分。 # nano /etc/drone/drone.toml 然后取消底下几行的注释并且补充上下面的内容。 [worker] nodes=[ "unix:///var/run/docker.sock", "unix:///var/run/docker.sock" ] 这里我们只设置了两个节点,这意味着上面的配置文件只能同时执行2 个构建操作。要提高并发性可以增大节点的值。 [worker] nodes=[ "unix:///var/run/docker.sock", "unix:///var/run/docker.sock", "unix:///var/run/docker.sock", "unix:///var/run/docker.sock" ] 使用上面的配置文件drone 被配置为使用本地的docker 守护程序可以同时构建4个任务。 ### 8. 重启 Drone ### 最后,当所有的安装和配置都准备好之后,我们现在要在本地的linux 机器上启动drone 服务器。 #### Ubuntu #### 因为ubuntu 14.04 使用了sysvinit 作为默认的init 系统,所以只需要简单执行下面的service 命令就可以启动drone 了。 # service drone restart 要让drone 在系统启动时也自动运行,需要运行下面的命令。 # update-rc.d drone defaults #### CentOS #### 因为CentOS 7使用systemd 作为init 系统,所以只需要运行下面的systemd 命令就可以重启drone。 # systemctl restart drone 要让drone 自动运行只需要运行下面的命令。 # systemctl enable drone ### 9. 添加防火墙例外 ### 众所周知drone 默认使用了80 端口而我们又没有修改他,所以我们需要配置防火墙程序允许80 端口(http)开发并允许其他机器可以通过网络连接。 #### Ubuntu 14.04 #### iptables 是最流行的防火墙程序,并且ubuntu 默认安装了它。我们需要修改iptable 暴露端口80,这样我们才能让drone 的web 界面在网络上被大家访问。 # iptables -A INPUT -p tcp -m tcp --dport 80 -j ACCEPT # /etc/init.d/iptables save #### CentOS 7 #### 因为CentOS 7 默认安装了systemd,它使用firewalld 作为防火墙程序。为了在firewalld 上打开80端口(http 服务),我们需要执行下面的命令。 # firewall-cmd --permanent --add-service=http success # firewall-cmd --reload success ### 10. 访问web 界面 ### 现在我们将在我们最喜欢的浏览器上通过web 界面打开drone。要完成这些我们要把浏览器指向运行drone 的服务器。因为drone 默认使用80 端口而我们有没有修改过,所以我们只需要在浏览器里根据我们的配置输入`http://ip-address/` 或 `http://drone.linoxide.com` 就行了。在我们正确的完成了上述操作后,我们就可以看到登陆界面了。 ![Login Github Drone](http://blog.linoxide.com/wp-content/uploads/2015/11/login-github-drone-e1446834688394.png) 因为在上面的步骤里配置了Github,我们现在只需要简单的选择github然后进入应用授权步骤,这些完成后我们就可以进入工作台了。 ![Drone Dashboard](http://blog.linoxide.com/wp-content/uploads/2015/11/drone-dashboard.png) 这里它会同步我们在github 上的代码库,然后询问我们要在drone 上构建那个代码库。 ![Activate Repository](http://blog.linoxide.com/wp-content/uploads/2015/11/activate-repository-e1446835574595.png) 这一步完成后,它会询问我们在代码库里添加`.drone.yml` 文件的新名称,并且在这个文件里定义构建的过程和配置项,比如使用那个docker 镜像,执行那些命令和脚本来编译,等等。 我们按照下面的内容来配置我们的`.drone.yml`。 image: python script: - python helloworld.py - echo "Build has been completed." 这一步完成后我们就可以使用drone 应用里的YAML 格式的配置文件来构建我们的应用了。所有对代码库的提交和改变此时都会同步到这个仓库。一旦提交完成了,drone 就会自动开始构建。 ![Building Application Drone](http://blog.linoxide.com/wp-content/uploads/2015/11/building-application-drone.png) 所有操作都完成后,我们就能在终端看到构建的结果了。 ![Build Success Drone](http://blog.linoxide.com/wp-content/uploads/2015/11/build-success-drone.png) ### 总结 ### 在本文中我们学习了如何安装一个可以工作的使用drone 的持续集成平台。如果我们愿意我们甚至可以从drone.io 官方提供的服务开始工作。我们可以根据自己的需求从免费的服务或者收费服务开始。它通过漂亮的web界面和强大的功能改变了持续集成的世界。它可以集成很多第三方应用和部署平台。如果你有任何问题、建议可以直接反馈给我们,谢谢。 -------------------------------------------------------------------------------- via: http://linoxide.com/linux-how-to/setup-drone-continuous-integration-linux/ 作者:[Arun Pyasi][a] 译者:[ezio](https://github.com/oska874) 校对:[校对者ID](https://github.com/校对者ID) 本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出 [a]:http://linoxide.com/author/arunp/ [1]:https://drone.io/ [2]:http://downloads.drone.io/master/drone.deb [3]:http://downloads.drone.io/master/drone.rpm [4]:https://github.com/settings/developers