<style> .textleft { text-align:left; } .reveal, .reveal h1, .reveal h2, .reveal h3, .reveal h4, .reveal h5, .reveal h6 { font-family:Arial, Microsoft JhengHei;} .reveal .progress { height: 14px !important; } .progress span { background: url() repeat-x !important; } .progress span:after, .progress span.nyancat { content: ""; background: url() ; width: 34px !important; height: 21px !important; border: none !important; float: right; margin-top: -7px; margin-right: -10px; } .my-icon-css { width: 100%; height: 200px; background-position:center; background-repeat: no-repeat; background-image:url('https://mir-s3-cdn-cf.behance.net/project_modules/disp/fe36cc42774743.57ee5f329fae6.gif'); } </style> <!-- .slide: data-transition="convex" --> # <h2>Drone 第一次 CI/CD 就上手</h2> @Kais(VagrantPi) ###### tags: `Drone`, `CI/CD`, `簡報` --- <!-- .slide: data-transition="convex" --> ## agenda ---- <!-- .slide: data-transition="convex" --> - 優缺點 - 架構 & 架設 - pipeline 教學 - command line - 好用的 plugin --- <!-- .slide: data-transition="convex" --> ## 優缺點 ---- <!-- .slide: data-transition="convex" --> ### 優點 - <h2><b>很潮</b></h2> - 學習成本低(會 docker 前提下) - 可加入版控 - 套件每種語言都能寫 - 支援大部分平台(Github/Bitbucket/Gitlab/Gogs) ---- <!-- .slide: data-transition="convex" --> ### 缺點 - 還很年輕(文件缺東缺西) - 套件還不夠多 - Web UI 過於簡陋(需要 command line 支援) --- <!-- .slide: data-transition="slide" --> ## 架構 & 架設 ---- <!-- .slide: data-transition="convex" --> ![](https://i.imgur.com/9qfjqAZ.png) ---- <!-- .slide: data-transition="convex" --> ### 架設(以 Bitbucket 為例) Bitbucket 設定 > View profile > OAuth > 詳細步驟可以直接參考上面第一篇連結,或是看我寫的 :smile: > [Re: 從零開始的 CI 生活 - Drone](https://vagrantpi.github.io/2018/09/28/drone-101/) ---- <!-- .slide: data-transition="convex" --> ### docker-compose ```diff version: '2' services: drone-server: image: drone/drone:0.8 ports: - 80:8000 - 9000 volumes: - /var/lib/drone:/var/lib/drone/ restart: always environment: - DRONE_OPEN=true # drone-server IP,如果要在 local 端測試,可以使用 ngrok - DRONE_HOST=${DRONE_HOST} # Set to true to enable the Bitbucket driver. + - DRONE_BITBUCKET=true # Bitbucket oauth2 client id + - DRONE_BITBUCKET_CLIENT=${DRONE_BITBUCKET_CLIENT} # Bitbucket oauth2 client secret + - DRONE_BITBUCKET_SECRET=${DRONE_BITBUCKET_SECRET} # drone server 與 agent 溝通的 secret key - DRONE_SECRET=${DRONE_SECRET} drone-agent: image: drone/agent:0.8 restart: always depends_on: - drone-server volumes: - /var/run/docker.sock:/var/run/docker.sock environment: # drone-server 位置 - DRONE_SERVER=drone-server:9000 # 跟上面的一樣 - DRONE_SECRET=${DRONE_SECRET} ``` http://docs.drone.io/install-for-bitbucket-cloud/ ---- <!-- .slide: data-transition="convex" --> ### Drone 上的帳號管理 ```diff services: drone-server: image: drone/drone:0.8 environment: + - DRONE_OPEN= true + - DRONE_ORGS: kaislin,joe_hsu ``` ---- <!-- .slide: data-transition="convex" --> ```diff services: drone-server: image: drone/drone:0.8 environment: - - DRONE_OPEN=true + - DRONE_OPEN=false + - DRONE_ADMIN=kaislin,joe_hsu ``` 這樣只能透過 admin 去手動添加 user ``` drone user add <username> ``` --- <!-- .slide: data-transition="convex" --> ## pipeline 教學 ---- <!-- .slide: data-transition="convex" --> > 跟 docker-compose 有 87% 像 ---- <!-- .slide: data-transition="convex" --> ### workspace(docker's volumes) ``` workspace: base: /go/src path: hello-drone ``` ---- <!-- .slide: data-transition="convex" --> ### tags ``` clone: git: image: plugins/git tags: true ``` ---- <!-- .slide: data-transition="convex" --> ### Service ```dockerfile services: database: image: mongo:4.0.2 environment: - MONGO_INITDB_ROOT_USERNAME=admin - MONGO_INITDB_ROOT_PASSWORD=admin - MONGO_INITDB_DATABASE=MYDB ``` ---- <!-- .slide: data-transition="convex" --> ### secrets ``` $ drone secret add \ --name MONGO_INITDB_ROOT_USERNAME \ --value admin \ --image mongo:4.0.2 \ --repository kaislin/hello-drone ``` or ![](https://i.imgur.com/IVsGEO4.png) ---- <!-- .slide: data-transition="convex" --> ```diff services: database: image: mongo:4.0.2 + secrets: [ MONGO_INITDB_ROOT_USERNAME, MONGO_INITDB_ROOT_PASSWORD] environment: - - MONGO_INITDB_ROOT_USERNAME=admin - - MONGO_INITDB_ROOT_PASSWORD=admin - MONGO_INITDB_DATABASE=MYDB ``` ---- <!-- .slide: data-transition="convex" --> ### 自訂 pipeline step ```dockerfile test: image: golang:1.9.4 volumes: - /home/ubuntu/hello-drone-config:/etc/mrt commands: - cp -rf config/hello-drone/router /hello-drone/mrt/ - cp -rf config/hello-drone/smtp /hello-drone/mrt/ - go test ./... - go test -cover ``` ---- <!-- .slide: data-transition="convex" --> ### 並行執行(Parallel Execution) ```diff pipeline: backend: + group: build image: golang commands: - go build - go test frontend: + group: build image: node commands: - npm install - npm run test - npm run build publish: image: plugins/docker repo: octocat/hello-world ``` ---- <!-- .slide: data-transition="convex" --> ### skip branch ```diff pipeline: build: image: golang commands: - go build - go test -branches: master -branches: [ master, develop ] +branches: [ master, feature/* ] ``` ---- <!-- .slide: data-transition="convex" --> ### 只關注的 branch ```diff pipeline: build: image: golang commands: - go build - go test +branches: + include: [ master, feature/* ] ``` ---- <!-- .slide: data-transition="convex" --> ### 排除 branch ```diff pipeline: build: image: golang commands: - go build - go test +branches: + exclude: [ develop, feature/* ] ``` ---- <!-- .slide: data-transition="convex" --> ### 當有 tag 時 ``` when: event: tag ``` ![](https://i.imgur.com/4XEdWxe.png) ---- <!-- .slide: data-transition="convex" --> ### Volumes 用法跟 docker-compose 差不多 ```diff pipeline: build: image: docker commands: - docker build --rm -t octocat/hello-world . - docker run --rm octocat/hello-world --test - docker push octocat/hello-world - docker rmi octocat/hello-world volumes: + - /var/run/docker.sock:/var/run/docker.sock ``` ![](https://i.imgur.com/Xiyv4jZ.png) ---- <!-- .slide: data-transition="convex" --> ### Environment ```diff pipeline: build: image: golang + environment: + - CGO=0 + - GOOS=linux + - GOARCH=amd64 commands: - go build - go test ``` ---- <!-- .slide: data-transition="convex" --> ### deploy ```diff pipeline: build: image: golang commands: - go build - go test publish: image: plugins/docker registry: registry.heroku.com repo: registry.heroku.com/my-staging-app/web when: + event: deployment + environment: staging publish_to_prod: image: plugins/docker registry: registry.heroku.com repo: registry.heroku.com/my-production-app/web when: + event: deployment + environment: production ``` ---- <!-- .slide: data-transition="convex" --> ### deploy command 部署使用 command line ``` drone deploy <repo> <build> <environment> ``` 指定部署 24 到 staging 環境 ``` drone deploy octocat/hello-world 24 staging ``` 指定部署 24 到 production 環境 ``` drone deploy octocat/hello-world 24 production ``` --- <!-- .slide: data-transition="convex" --> ## command line ---- <!-- .slide: data-transition="convex" --> ### token 使用前須先從 web UI 拿到 token 才能夠透過 command 戳 drone ---- <!-- .slide: data-transition="convex" --> ### build drone build start kaislin/hello-drone 36 drone build stop kaislin/hello-drone 36 --- <!-- .slide: data-transition="convex" --> ## 好用的 plugin ---- <!-- .slide: data-transition="convex" --> ### ssh ```dockerfile deploy-production: image: appleboy/drone-ssh pull: true host: <host ip> username: <username> secrets: [ ssh_password ] script: - docker pull XXX.XXX.XXX.XXX:5000/hello-drone - docker tag XXX.XXX.XXX.XXX:5000/hello-drone hello-drone:latest - cd /home/ubuntu/hello-drone/docker - docker-compose down - docker-compose up -d when: branch: develop event: deployment ``` ---- <!-- .slide: data-transition="convex" --> ### slack ```dockerfile slack: image: plugins/slack channel: drone_test webhook: https://hooks.slack.com/services/..... when: status: [ success, failure ] ``` ---- <!-- .slide: data-transition="convex" --> ### cache 如 node_module 或 vendor 之類的資料希望能夠 cache ```dockerfile restore-cache: image: drillster/drone-volume-cache restore: true mount: - ./vendor volumes: - /tmp/cache:/cache dependency: image: marcelocorreia/go-glide-builder commands: - sh docker/glide_install.sh rebuild-cache: image: drillster/drone-volume-cache rebuild: true mount: - ./vendor volumes: - /tmp/cache:/cache ```
{"metaMigratedAt":"2023-06-14T18:19:34.315Z","metaMigratedFrom":"Content","title":"<h2>Drone 第一次 CI/CD 就上手</h2>","breaks":true,"contributors":"[{\"id\":\"69ade472-3ed3-499d-8a69-767243a31621\",\"add\":18439,\"del\":3514}]"}
    1509 views