您好,登錄后才能下訂單哦!
這篇文章主要介紹“Gitlab Flow與DevOps流程舉例分析”,在日常操作中,相信很多人在Gitlab Flow與DevOps流程舉例分析問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Gitlab Flow與DevOps流程舉例分析”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
操作
為在迭代便利性、部署嚴謹性上取得平衡,項目組(其實是我~。。~啦)設計了如下Gitlab flow & DevOps流程。
一個完整的迭代上線周期:
這里為什么保留master分支, 是因為理論上當feature分支合并回develop分支,develop已經被污染了,這里保留master只為兜底。
后續就是開始新的sprint周期了,git release分支名/tag標簽名跟隨迭代。
整個過程貫徹了git flow 預發布分支release,hotfix的核心用法, 同時在部署方式上也有一定的改進。
集成測試采用docker-compose部署;alpha,prod是采用k8s部署;從上面的Gitlab flow 知道:
Git develop分支、release-分支、tag標簽、master分支會打出容器鏡像, Git develop分支代碼(ImageTag:develop)(只)會自動部署集成測試環境, Git release- 分支(ImageTag:release-1.0.0)(只)會自動部署到alpha, Git tag標簽(ImageTag:v1.0.0) 手動點擊部署到prod
stages:
- build
- build_image
- deploy
variables:
deploy_path: "/home/eap/website"
build:
stage: build
script:
- pwd
- "for d in $(ls app/src);do echo $d;pro=$(pwd)/app/src/$d/$d.csproj; dotnet build $pro; done"
tags:
- my-tag
build_image:EAPWebsite:
stage: build_image
script:
- dotnet publish app/src/EAP.Web/EAP.Web.csproj -c release -o container/app/publish/
- docker build -t $DOCKER_REGISTRY_HOST/eap/website:$CI_COMMIT_REF_NAME container/app
- docker login $DOCKER_REGISTRY_HOST -u $CI_REGISTRY_USER -p $CI_REGISTRY_PASSWORD
- docker push $DOCKER_REGISTRY_HOST/eap/website:$CI_COMMIT_REF_NAME
tags:
- my-tag
only:
- tags
- develop
- master
- /^release-.*$/i
deploy:intergate-test:
stage: deploy
script:
- ssh -t testUser@10.202.42.252 "cd /home/eap/website && export TAG=$CI_COMMIT_REF_NAME && docker-compose pull website && docker-compose -f docker-compose.yml up -d"
tags:
- my-tag
only:
- develop # 開發階段,intergate Test環境只會部署ImageTag:develop鏡像
deploy:alpha:
stage: deploy
script:
- ssh -t testUser@10.201.82.170 "sudo kubectl set image deployment/eap-website eap-website=repository.****.com:8443/eap/website:${CI_COMMIT_REF_NAME} && sudo kubectl rollout status deployment/eap-website"
tags:
- my-tag
only:
- /^release-.*$/i # alpha環境只部署以ImageTag:release-開頭鏡像
deploy:prod:
stage: deploy
script:
- ssh -t testUser@10.202.42.20 "sudo kubectl set image deployment/eap-website eap-website=repository.****.com:8443/eap/website:${CI_COMMIT_REF_NAME} && sudo kubectl rollout status deployment/eap-website"
tags:
- my-tag
only:
- tags
- master
when: manual # prod環境,人工點擊部署
到此,關于“Gitlab Flow與DevOps流程舉例分析”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。