kubernetes-handbook/practice/drone-ci-cd.md

2.8 KiB
Raw Blame History

使用Drone进行持续构建与发布

Drone是一个用Go语言开发的基于容器运行的持续集成软件。

配置GitHub

使用Drone对GitHub上的代码进行持续构建与发布需要首先在GitHub上设置一个OAuth如下

1. 在Github上创建一个新的OAtuh应用

访问https://github.com/settings/applications/new创建新的OAuth应用

OAuth注册

填写应用程序的地址,因为是在本地与行,所以我们都填http://localhost

2. 获取OAtuh Client ID和Client Secret

在注册完成后就可以获得如下图所示的OAuth Client ID和Client Secret保存下来我们后面要用到。

OAuth key

使用docker-compose单机运行

我们在本地环境使用docker-compose按照Drone官方安装文档安装配置Drone。

我们将代码托管在Github上需要Drone可以持续集成和发布Github的代码因此需要修改docker-compoe.yaml文件中的GitHub配置。

version: '2'

services:
  drone-server:
    image: drone/drone:0.7
    ports:
      - 80:8000
    volumes:
      - /var/lib/drone:/var/lib/drone/
    restart: always
    environment:
      - DRONE_OPEN=true
      - DRONE_ADMIN=jimmy
      - DRONE_HOST=localhost
      - DRONE_GITHUB=true
      - DRONE_GITHUB_CLIENT=${DRONE_GITHUB_CLIENT}
      - DRONE_GITHUB_SECRET=${DRONE_GITHUB_SECRET}
      - DRONE_SECRET=admin
  drone-agent:
    image: drone/drone:0.7
    command: agent
    restart: always
    depends_on:
      - drone-server
    volumes:
      - /var/run/docker.sock:/var/run/docker.sock
    environment:
      - DRONE_SERVER=ws://drone-server:8000/ws/broker
      - DRONE_SECRET=admin
  • /var/lib/drone是在本地挂载的目录请确保该目录已存在且可以被docker访问到Mac下可以在docker的共享目录中配置。
  • DRONE_SECRET可以是一个随机的字符串,要确保drone-serverdrone-clientDRONE_SECRET相同。
  • DRONE_GITHUB_CLIENTDRONE_GITHUB_SECRET即在前面申请的OAuth的Client ID和Client Secret。

启动Drone

使用下面的命令在本地启动drone

docker-compose up

这样是在前台启动,加上-d参数就可以在后台启动。

访问http://localhost可以看到登陆画面

Drone登陆界面

授权后可以看到GitHub repo设置。

Github启用repo设置

Github单个repo设置

参考