data:image/s3,"s3://crabby-images/9ee4d/9ee4db22dff715a27f254426df0e88a1a7eb54ae" alt=""
data:image/s3,"s3://crabby-images/6766b/6766b963027de6ce6497038e92660807dd866521" alt=""
WHY GITLAB-CI
WHY GITLAB-CI
vs Jenkins
data:image/s3,"s3://crabby-images/2139a/2139a89fd1db7632ff336e5c641435da23c16fb2" alt=""
data:image/s3,"s3://crabby-images/f19a9/f19a9acdcd24593cd8c514e3e68119805a56e0f4" alt=""
ABOUT JENKINS
The powerful CI system
Framework
- 延展性 (成堆的Plugin)
- 所有配置都可以在 Jenkins 上做完
- 自由度爆表 (sheeeellscript!)
- 報表
data:image/s3,"s3://crabby-images/9545d/9545df717bb69b67357e62ce9c18ea4646a4c648" alt=""
data:image/s3,"s3://crabby-images/f0e99/f0e9933a7f3e6e9a987d45c2af53b8220a806518" alt=""
data:image/s3,"s3://crabby-images/0352b/0352bc26931cd360ec07537a7fbba5019ca1aac4" alt=""
data:image/s3,"s3://crabby-images/3f6fe/3f6fefa2326a1c48b0550dea82c5c5c8f0e4228d" alt=""
data:image/s3,"s3://crabby-images/0b8b2/0b8b2751685df20316e0963ed94782cebc993d3c" alt=""
data:image/s3,"s3://crabby-images/6766b/6766b963027de6ce6497038e92660807dd866521" alt=""
data:image/s3,"s3://crabby-images/343cb/343cba1d3caef67cc5c541a7473d611592ca2d95" alt=""
data:image/s3,"s3://crabby-images/56b7e/56b7ec20da0f3d10fd2fbb120b337b0e5d2d9b6d" alt=""
WHY GITLAB-CI
其實只是想偷懶
(簡單一點世界和平)
- 懶人包整合 gitlab
- 所有動作都可以寫 yml 完成 (不負責發言)
- 維護上相對簡單
.gitlab-ci.yml
Configuration of your jobs
data:image/s3,"s3://crabby-images/cedc8/cedc885256f0fe8b12760d496305cd9813146fb4" alt=""
data:image/s3,"s3://crabby-images/e64dc/e64dcacc0030db1965147b3dcdc83418d780496a" alt=""
data:image/s3,"s3://crabby-images/6766b/6766b963027de6ce6497038e92660807dd866521" alt=""
data:image/s3,"s3://crabby-images/cedc8/cedc885256f0fe8b12760d496305cd9813146fb4" alt=""
data:image/s3,"s3://crabby-images/e64dc/e64dcacc0030db1965147b3dcdc83418d780496a" alt=""
起手式 → stages
stages:
- prepare
- lint
- test
- build
- package
- deploy
stages 中會有哪些 job
stages:
- prepare
- lint
- test
- build
- package
- deploy
app:installing_dependencies:
image: $NODE_IMAGE
stage: prepare
script:
- cd app/
- npm install
retry: 2
artifacts:
paths:
- app/node_modules
crawler:installing_dependencies:
image: $NODE_IMAGE
stage: prepare
script:
- cd crawler/
- npm install
retry: 2
artifacts:
paths:
- crawler/node_modules
share:installing_dependencies:
image: $NODE_IMAGE
stage: prepare
script:
- cd share/
- npm install
retry: 2
artifacts:
paths:
- share/node_modules
variables:
NODE_IMAGE: node:10.13.0
Okay, it looks good
BUT...
app:installing_dependencies:
image: $NODE_IMAGE
stage: prepare
script:
- cd app/
- npm install
retry: 2
artifacts:
paths:
- app/node_modules
crawler:installing_dependencies:
image: $NODE_IMAGE
stage: prepare
script:
- cd crawler/
- npm install
retry: 2
artifacts:
paths:
- crawler/node_modules
share:installing_dependencies:
image: $NODE_IMAGE
stage: prepare
script:
- cd share/
- npm install
retry: 2
artifacts:
paths:
- share/node_modules
data:image/s3,"s3://crabby-images/51d19/51d19a6bfc142442b08dfd4d0239a31961402ef6" alt=""
data:image/s3,"s3://crabby-images/2cf89/2cf89b6575018202ba639ad96ae5839bc72ede8d" alt=""
artifacts 實際上...?
data:image/s3,"s3://crabby-images/cb3ab/cb3ab03c398d6ce045bf91ed7a965e70a2d10929" alt=""
app:ensure_the_code_quality:
image: $NODE_IMAGE
stage: lint
dependencies:
- app:installing_dependencies
script:
- cd app/
- npm run lint
allow_failure: true
data:image/s3,"s3://crabby-images/f1029/f1029773d435e4058411964a1777d5ecedddaa8a" alt=""
data:image/s3,"s3://crabby-images/31a6b/31a6b8bbec7c9ea9419a0923d5d1006b2ecdeac8" alt=""
Everything goes right
UNTIL...
Build the docker image
app:docker-build:
stage: package
dependencies:
- build_static_assets
script:
- echo $VERSION > app/version
- docker build -f app/Dockerfile -t $APP_GCR:$VERSION .
- docker push $APP_GCR:$VERSION
only:
- tags
variables:
NODE_ENV: production
VERSION: $CI_COMMIT_TAG
Yeah! You're good to go, kid!
WAIT
data:image/s3,"s3://crabby-images/a0b5a/a0b5ac6567b0ec19b3be058123bc2a071dfd87f1" alt=""
gitlab-runner 是 base on docker...
那在 docker 內跑 docker...
data:image/s3,"s3://crabby-images/6c9b5/6c9b557efcee448fd4a6d276a74f187779a142ba" alt=""
Docker in Docker
HOW?
data:image/s3,"s3://crabby-images/6883d/6883dd75f41e0e35cdc7ac1252ce6d5cc23328d6" alt=""
Docker in Docker
Yeah! Hold on......WAAAAT!?
data:image/s3,"s3://crabby-images/36bac/36baccccb418fcae92bc6a36c115704cd7bdee68" alt=""
data:image/s3,"s3://crabby-images/cfc7b/cfc7b774a32a9fa01fc34977b977963b865caddf" alt=""
Docker in Docker
data:image/s3,"s3://crabby-images/6581a/6581affd22e62058d6289a2118168e96bc4c2572" alt=""
data:image/s3,"s3://crabby-images/6766b/6766b963027de6ce6497038e92660807dd866521" alt=""
Docker in Docker
總的來說,還得補一些東西上去 - 1
[[runners]]
url = "https://gitlab.com/"
token = TOKEN
executor = "docker"
[runners.docker]
tls_verify = false
image = "docker:stable"
privileged = true
disable_cache = false
volumes = ["/cache"]
[runners.cache]
Insecure = false
首先得在 gitlab runner 加上 privileged flag
Docker in Docker
總的來說,還得補一些東西上去 - 2A
app:docker-build:
image: docker:stable
stage: package
dependencies:
- build_static_assets
services:
- docker:dind
script:
- echo $VERSION > app/version
- docker build -f app/Dockerfile -t $APP_GCR:$VERSION .
- docker push $APP_GCR:$VERSION
only:
- tags
variables:
NODE_ENV: production
VERSION: $CI_COMMIT_TAG
DOCKER_HOST: tcp://docker:2375/
DOCKER_DRIVER: overlay2
然後在你的 gitlab-ci.yml 加上需要的 variable
以及引用服務 dind
Docker in Docker
總的來說,還得補一些東西上去 - 2A+
variables:
# When using dind service we need to instruct docker, to talk with the
# daemon started inside of the service. The daemon is available with
# a network connection instead of the default /var/run/docker.sock socket.
#
# The 'docker' hostname is the alias of the service container as described at
# https://docs.gitlab.com/ee/ci/docker/using_docker_images.html#accessing-the-services
#
# Note that if you're using Kubernetes executor, the variable should be set to
# tcp://localhost:2375 because of how Kubernetes executor connects services
# to the job container
DOCKER_HOST: tcp://docker:2375/
# When using dind, it's wise to use the overlayfs driver for
# improved performance.
DOCKER_DRIVER: overlay2
DOCKER_HOST 用來讓 docker 知道 service deamon 在哪裡
DOCKER_DRIVER 則是用來改善效能
Docker in Docker
總的來說,還得補一些東西上去 - 2B
[[runners]]
url = "https://gitlab.com/"
token = REGISTRATION_TOKEN
executor = "docker"
[runners.docker]
tls_verify = false
image = "docker:stable"
privileged = false
disable_cache = false
volumes = ["/var/run/docker.sock:/var/run/docker.sock", "/cache"]
[runners.cache]
Insecure = false
或是另一個方式,掛上自己,但是會有造成所有 container 都會是 runner 的兄弟,而不是 runner 的子節點
在官方文件上有提到這種方式只適用於極少情況
Docker in Docker
app:docker-build:
image: docker:stable
stage: package
dependencies:
- build_static_assets
services:
- docker:dind
script:
- echo $VERSION > app/version
- docker build -f app/Dockerfile -t $APP_GCR:$VERSION .
- docker push $APP_GCR:$VERSION
only:
- tags
variables:
NODE_ENV: production
VERSION: $CI_COMMIT_TAG
DOCKER_HOST: tcp://docker:2375/
DOCKER_DRIVER: overlay2
data:image/s3,"s3://crabby-images/e89bf/e89bf50e8e001e7546052f5f20ffe118a9bd46cf" alt=""
HOW?
CREDENTIAL??
data:image/s3,"s3://crabby-images/e52c6/e52c68453308d9b9d9bdb90d20525748fc0e3d25" alt=""
I need google cloud sdk...
I don't wanna create any credential files...
And support docker in docker...
data:image/s3,"s3://crabby-images/55248/5524811ef822c711669b358cf976e1cb039c00df" alt=""
data:image/s3,"s3://crabby-images/28261/282612abf467d7aa665c8f8506691e9e83df012b" alt=""
Text
data:image/s3,"s3://crabby-images/d3400/d3400d91123f3c63b2bea2d912d806feac391eef" alt=""
data:image/s3,"s3://crabby-images/28261/282612abf467d7aa665c8f8506691e9e83df012b" alt=""
app:docker-build:
image: mtpeak/google-cloud-sdk-with-kubectl:docker
stage: package
dependencies:
- build_static_assets
services:
- docker:dind
before_script:
- gcloud auth configure-docker -q
script:
- echo $VERSION > app/version
- gsutil cp -r app/.nuxt/dist gs://$ASSETS_GCS_BUCKET_NAME/$VERSION
- docker build -f app/Dockerfile -t $APP_GCR:$VERSION .
- docker push $APP_GCR:$VERSION
only:
- tags
variables:
NODE_ENV: production
VERSION: $CI_COMMIT_TAG
DOCKER_HOST: tcp://docker:2375/
DOCKER_DRIVER: overlay2
Yeah! You're good to go, kid!
- docker build 可維護性
- runner executor with docker-machine => scalable + 不用想 credential 該怎麼丟 (
等等,我好像沒講到 executor 設定相關) - gitlab-ci.yml 易讀好學外加很多參數可以用,不需要寫 script 拿值
- 無痛整合 gitlab
Wrap it up
- 準備個 slack bot 做 production deploy confirm (build 完後在 slack 確認才做 k8s update)
- 整理 cache 讓流程可以跑快一點
- 搬家到 DRONE
The next...
data:image/s3,"s3://crabby-images/1e600/1e6003995ba4921823f996db0bb6e9f9773d8937" alt=""
Introduce the gitlab-CI
By Calvin Huang
Introduce the gitlab-CI
- 1,747