經常會聽到持續整合,持續交付,持續部署,三者究竟是什麼,有何聯絡和區別呢?
假如把開發工作流程分為以下幾個階段:
編碼 -> 構建 -> 整合 -> 測試 -> 交付 -> 部署正如你在上圖中看到,「持續整合(continuous integration)」、「持續交付(continuous delivery)」和「持續部署(continuous deployment)」有著不同的軟體自動化交付週期。
持續整合是指軟體個人研發的部分向軟體整體部分交付,頻繁進行整合以便更快地發現其中的錯誤。「持續整合」源自於極限程式設計(xp),是 xp 最初的 12 種實踐之一。
ci 需要具備這些:
持續整合的優點
持續整合,該從何入手
最重要的一環是選擇合適的持續整合系統。是搭建私有部署還是選擇託管型持續整合系統,關鍵在於團隊執行的基礎設施,團隊對持續整合系統的資源投入力度。
對比一下私有部署和託管型持續整合系統,或許能幫助你更好地做出選擇。
整體而言,jenkins 過去一直是大部分公司的選擇,但這個現象正在發生改變,隨著公有雲服務、docker,saas 的普及,越來越多的企業開始選擇 hosted ci,也就是託管型持續整合系統。
另外,在選擇合適的持續整合服務時,還需要考量系統的靈活度以適應公司不同階段的開發測試需求。
選擇持續整合系統只是持續整合應用的其中一步,還需要建立合適的持續整合文化比如**質量管控、測試文化等。做好持續整合,可為持續交付與持續部署打好堅實基礎。
持續交付在持續整合的基礎上,將整合後的**部署到更貼近真實執行環境的「類生產環境」(production-like environments)中。持續交付優先於整個產品生命週期的軟體部署,建立在高水平自動化持續整合之上。
試想想,如果說等到所有東西都完成了才向下個環節交付,導致所有的問題只能再最後才爆發出來,解決成本巨大甚至無法解決。比如,我們完成單元測試後,可以把**部署到連線資料庫的 staging 環境中進行更多的自動化測試。如果**沒有問題,可以繼續手動部署到生產環境中。當然,持續交付並不是指軟體每乙個改動都要盡快部署到產品環境中,它指的是任何的**修改都可以在任何時候實施部署。
持續交付的好處
持續交付和持續整合的優點非常相似:
持續部署是指當交付的**通過評審之後,自動部署到生產環境中。持續部署是持續交付的最高端段。這意味著,所有通過了一系列的自動化測試的改動都將自動部署到生產環境。它也可以被稱為「continuous release」。
為什麼說持續部署是理想的工作流程?
「開發人員提交**,持續整合伺服器獲取**,執行單元測試,根據測試結果決定是否部署到預演環境,如果成功部署到預演環境,進行整體驗收測試,如果測試通過,自動部署到產品環境,全程自動化高效運轉。」實際上,產品在從需求到部署的過程中,會經歷若干種不同的環境,例如 qa 環境、各種自動化測試執行環境、生產環境等。這些環境的搭建、配置、管理,產品在不同環 境中的具體部署,狀況是比較非常複雜的,從頭到尾地全自動持續部署的確困難。那麼,如果能做到持續交付,保證**在模擬環境沒問題,也許團隊成員做到真正的心理有數。
持續部署的優點
持續部署主要好處是,可以相對獨立地部署新的功能,並能快速地收集真實使用者的反饋。
「you build it, you run it」,這是 amazon 一年可以完成 5000 萬次部署,平均每個工程師每天部署超過 50 次的核心秘籍。「持續整合(continuous integration)」、「持續交付(continuous delivery)」和「持續部署(continuous deployment)」提供了乙個優秀的 devops 環境,對於整個團隊來說,好處與挑戰並行。無論如何,頻繁部署、快速交付以及開發測試流程自動化都將成為未來軟體工程的重要組成部分。
歡迎分享你的觀點。
【參考文章】
談談持續整合 持續交付 持續部署
經常會聽到持續整合,持續交付,持續部署,三者究竟是什麼,有何聯絡和區別呢?什麼是 持續 所謂的持續,就是說每完成乙個完整的部分,就向下個環節交付,發現問題可以馬上調整。是的問題不會放大到其他部分和後面的環節。這種做法的核心思想在於 既然事實上難以做到事先完全了解完整的 正確的需求,那麼就乾脆一小塊一...
持續整合 持續交付 持續部署
持續整合 持續整合強調開發人員提交了新 之後,立刻進行構建 單元 測試。根據測試結果,我們可以確定新 和原有 能否正確地整合在一起。持續交付 持續交付在持續整合的基礎上,將整合後的 部署到更貼近真實執行環境的 類生產環境 production like environments 中。比如,我們完成單...
持續整合 持續交付 持續部署
參考 1 continuous integration 持續整合 持續整合強調對於開發人員的每個提交,立刻進行構建 單元 測試。根據測試結果,我們可以確定新 和原有 能否正確地整合在一起。2 continuous delivery 持續交付 持續交付在持續整合的基礎上,將整合後的 部署到更貼近真實執...