CI/CD 持續集成和持續交付 (二)

根據上次的文章介紹,制定了一套解決方案

此套方案 作爲 PaaS 或者SaaS 都是棒棒的,結合着OpenStack 作爲IaaS層 更適合,

整體的思路大概是這樣的,後續會詳細介紹。

客戶或產品有新的需求變更,或者測試人員提出bug時,會在redmine服務上創建提交事件,開發人員得到通知,會對開發分支做修改,每個項目會有不同的分支。

分支中會包含一個名叫Docker的目錄,裏面包含了將整個項目的build輸出(對於Java的web應用來說就是war文件),打包成docker p_w_picpath所需要的文件。

項目使用Git來做源代碼管理,Git服務器爲私有的Gitlab。

開發人員提交代碼並push到Gitlab,Gitlab觸發Web Hook,通知Jenkins項目有新的變更。Jenkins收到通知,從Gitlab pull代碼並自動啓動編譯構建。

如果構建成功調用docker的目錄下腳本來生成docker p_w_picpath並push到私有docker倉庫上。

通過chef,通知最終的部署節點,下載最新版p_w_picpath,刪除正在運行的容器,以新p_w_picpath來啓動容器,完成項目的更新。整個過程會在短短幾分鐘就能看到結果。


wKiom1jYb0bhJCe2AAFDvfiwWLs534.png-wh_50

後續會編寫:

Gitlab  私有倉庫搭建及注意事項

Docker 私有倉庫搭建及注意事項

Jenkins 搭建及注意事項

Chef   搭建及注意事項

Redmine 搭建及使用方法和注意事項

未完待續....


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章