: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 的设置里创建一个新的应用:https://github.com/settings/developers 。
要创建一个应用,我们需要在 New Application 页面点击 Register,然后如下所示填表。
我们应该保证在应用的配置项里设置了授权回调链接,链接看起来类似 http://drone.linoxide.com/api/auth/github.com。然后我们点击注册应用。所有都做好之后我们会看到我们需要在我们的 Drone 配置文件里配置的客户端 ID 和客户端密钥。
在这些都完成之后我们需要使用文本编辑器编辑 drone 配置文件,比如使用下面的命令。
代码如下:
# nano /etc/drone/drone.toml
然后我们会在 drone 的配置文件里面找到[github] 部分,紧接着的是下面所示的配置内容
代码如下:
[github]
client="3dd44b969709c518603c"
secret="4ee261abdb431bdc5e96b19cc3c498403853632a"
# orgs=[]
# open=false
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"
注意:这里的 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 作为默认的初始化系统,所以只需要简单执行下面的 service 命令就可以启动 drone 了。
代码如下:
# service drone restart
要让 drone 在系统启动时也自动运行,需要运行下面的命令。
代码如下:
# update-rc.d drone defaults
CentOS
因为 CentOS 7使用 systemd 作为初始化系统,所以只需要运行下面的 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 就行了。在我们正确的完成了上述操作后,我们就可以看到登录界面了。
因为在上面的步骤里配置了 Github,我们现在只需要简单的选择 github 然后进入应用授权步骤,这些完成后我们就可以进入工作台了。
这里它会同步我们在 github 上的代码库,然后询问我们要在 drone 上构建那个代码库。
这一步完成后,它会询问我们在代码库里添加.drone.yml 文件的新名称,并且在这个文件里定义构建的过程和配置项,比如使用那个 docker 镜像,执行那些命令和脚本来编译,等等。
我们按照下面的内容来配置我们的.drone.yml。
复制代码
代码如下:
image: python
script:
- python helloworld.py
- echo "Build has been completed."
这一步完成后我们就可以使用 drone 应用里的 YAML 格式的配置文件来构建我们的应用了。所有对代码库的提交和改变此时都会同步到这个仓库。一旦提交完成了,drone 就会自动开始构建。
所有操作都完成后,我们就能在终端看到构建的结果了。

学习教程快速掌握从入门到精通的电脑知识
关键词:Linux中安装部署Docker管理工具Drone全攻略