CI / CD 流程(適合中小型公司)

前言

架構(gòu)圖
機器準備(3臺)
  • CI / CD 10.0.4.3(Drone + Gogs + SonarQube)
  • Docker 鏡像倉庫 10.0.4.22(Harbor)
  • 測試環(huán)境 10.0.4.50

SonarQube

安裝 SonarQube
docker run -d --name sonarqube -p 9000:9000 --net mynetwork --ip 172.18.0.5 --restart=always sonarqube:alpine
安裝 中文語言包

安裝完成后,點擊 restart,重啟 SonarQube 服務(wù)器

默認賬密
賬號:admin
密碼:admin


Gogs

安裝 Gogs
docker run -d --name=gogs --restart=always -p 3000:3000 -p 3001:22 -v /docker/gogs:/data  --net mynetwork --ip 172.18.0.2 gogs/gogs
配置 Gogs
克隆倉庫

Drone

安裝 Drone
docker run \
  --volume=/var/lib/drone:/data \
  --env=DRONE_AGENTS_ENABLED=true \
  --env=DRONE_GOGS_SERVER=http://172.18.0.2:3000 \
  --env=DRONE_RPC_SECRET=drone666 \
  --env=DRONE_SERVER_HOST=172.18.0.3 \
  --env=DRONE_SERVER_PROTO=http \
  --env=DRONE_LOGS_TRACE=true \
  --env=DRONE_USER_CREATE=username:public,admin:true \
  --publish=80:80 \
  --publish=443:443 \
  --restart=always \
  --detach=true \
  --name=drone \
  --net mynetwork \
  --ip 172.18.0.3 \
  drone/drone:1
安裝 Drone-runner
docker run -d \
  -v /var/run/docker.sock:/var/run/docker.sock \
  -e DRONE_RPC_PROTO=http \
  -e DRONE_RPC_HOST=172.18.0.3 \
  -e DRONE_RPC_SECRET=drone666 \
  -e DRONE_RUNNER_CAPACITY=2 \
  -e DRONE_RUNNER_NAME=${HOSTNAME} \
  -e DRONE_LOGS_TRACE=true \
  -e DRONE_RUNNER_NETWORKS=mynetwork \
  -p 81:3000 \
  --restart always \
  --name runner \
  --net mynetwork \
  --ip 172.18.0.4 \
  drone/drone-runner-docker:1
登錄 Drone

使用 Gogs 賬號

同步 Gogs 倉庫
激活 Gogs 倉庫

該步驟會在 Gogs 倉庫中,生成 WebHook

開啟 Drone 信任模式
查看 Gogs WebHook
測試 Gogs WebHook

Harbor

安裝 docker-compose
yum install docker-compose
安裝 Harbor
mkdir ~/software && cd ~/software
wget https://github.com/goharbor/harbor/releases/download/v1.9.3/harbor-offline-installer-v1.9.3.tgz
tar -xvf harbor-offline-installer-v1.9.3.tgz
cd ~/harbor
配置 Harbor
// harbor.yml
hostname: 10.0.4.22
http:
  port: 80
啟動 Harbor
./install.sh

默認帳密
賬號:admin
密碼:[ harbor.yml password ]

創(chuàng)建倉庫

編輯項目

該環(huán)節(jié),以 JavaScript 前端項目為例

初始化項目
yarn init -y
yarn add -D parcel-bundler
配置腳本
// package.json
"scripts": {
    "build": "parcel build index.html"
  },
創(chuàng)建項目入口
// index.html
<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title></title>
    </head>
    <body>
        <p>888888888</p>
    </body>
</html>
創(chuàng)建 drone 配置文件
// .drone.yml
kind: pipeline
name: default

steps:
- name: restore-cache
  image: drillster/drone-volume-cache
  volumes:
    - name: cache
      path: /cache
  settings:
    restore: true
    mount:
     - ./node_modules

- name: code-analysis
  image: aosapps/drone-sonar-plugin
  settings:
    SONAR_HOST: http://172.18.0.5:9000

- name: build-frontend
  image: node
  commands:
  - yarn install
  - yarn build

- name: rebuild-cache
  image: drillster/drone-volume-cache
  volumes:
    - name: cache
      path: /cache
  settings:
    rebuild: true
    mount:
     - ./node_modules

- name: upload-docker
  image: plugins/docker
  settings:
    repo: 10.0.4.22/repo_drone/image_drone
    registry: 10.0.4.22
    username: public
    password: Abcdefg123
    tags: v1.0.0
    insecure: true
    debug: true
    dockerfile: Dockerfile

- name: ssh run
  image: appleboy/drone-ssh
  settings:
    host: 10.0.4.50
    username: root
    password: gdhr@123
    port: 22
    script:
      - docker pull 10.0.4.22/repo_drone/image_drone:v1.0.0
      - docker run -d -p 1111:80 --restart=always 10.0.4.22/repo_drone/image_drone:v1.0.0

volumes:  
  - name: cache  
    host:  
      path: /tmp/cache_drone
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容