• 使用Drone进行持续构建与发布
    • 配置GitHub
    • 使用docker-compose单机运行
      • 启动Drone
    • 参考

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

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

    配置GitHub

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

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

    访问此頁面,创建新的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-compose.yaml文件中的GitHub配置。

    1. version: '2'
    2. services:
    3. drone-server:
    4. image: drone/drone:0.8
    5. ports:
    6. - 80:8000
    7. - 9000
    8. volumes:
    9. - /var/lib/drone:/var/lib/drone/
    10. restart: always
    11. environment:
    12. - DRONE_OPEN=true
    13. - DRONE_HOST=${DRONE_HOST}
    14. - DRONE_GITHUB=true
    15. - DRONE_GITHUB_CLIENT=${DRONE_GITHUB_CLIENT}
    16. - DRONE_GITHUB_SECRET=${DRONE_GITHUB_SECRET}
    17. - DRONE_SECRET=${DRONE_SECRET}
    18. drone-agent:
    19. image: drone/agent:0.8
    20. command: agent
    21. restart: always
    22. depends_on:
    23. - drone-server
    24. volumes:
    25. - /var/run/docker.sock:/var/run/docker.sock
    26. environment:
    27. - DRONE_SERVER=drone-server:9000
    28. - DRONE_SECRET=${DRONE_SECRET}
    • /var/lib/drone是在本地挂载的目录,请确保该目录已存在,且可以被docker访问到,Mac下可以在docker的共享目录中配置。
    • DRONE_SECRET可以是一个随机的字符串,要确保drone-serverdrone-clientDRONE_SECRET相同。
    • DRONE_GITHUB_CLIENTDRONE_GITHUB_SECRET即在前面申请的OAuth的Client ID和Client Secret。

    启动Drone

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

    1. docker-compose up

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

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

    Drone登陆界面

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

    Github启用repo设置

    Github单个repo设置

    参考

    • Drone Installation
    • Github - Drone
    • Drone 搭配 Kubernetes 升級應用程式版本 - blog.wu-boy.com