摘要:今天,我們來了解下什麼是「持續交付」及「持續交付」的實踐。
雲原生是當下IT圈非常熱門的一個詞,其目的是為了各組織在公有云、私有云和混合雲等新型動態環境中,構建和執行可彈性擴充套件的應用。雲原生包含很多技術,比如容器、微服務、DevOps、持續交付等,今天,我們來了解下什麼是「持續交付」及「持續交付」的實踐。
持續交付是指,所有開發人員都在主幹上進行小批次工作,或者在短時間存在的特性分支上工作且定期向主幹合併,同時始終讓主幹保持可釋出狀態,保證程式碼可以按需進行一鍵式釋出。開發人員在引入任何迴歸錯誤時(包括缺陷、效能問題、安全問題、可用性問題等),都能快速得到反饋。一旦發現這類問題,就立即加以解決,從而保持主幹始終處於可部署狀態。
( Wikipedia: Continuous delivery (CD) is a software engineering approach in which teams produce software in short cycles, ensuring that the software can be reliably released at any time. )
持續交付是持續整合的延伸,將整合後的程式碼部署到類生產環境,確保可以以可持續的方式快速向客戶釋出新的更改。如果程式碼沒有問題,可以繼續手動部署到生產環境中。
隨著開發模式的日益成熟,軟體開發過程中的每個環節已經越來越標準化了,但是這些環節都相對獨立,需要一個東西將他們連線成一個整體。
如果我們能將這些環節——構建、釋出、測試、部署有效的串聯起來,形成一套完成的持續交付流水線,就能提高軟體的釋出效率與質量,持續不斷的創造業務價值。
持續交付流水線工作流程大致如下:
當然,流程並非固定的,可以根據具體的業務需要,穿插其他流程,比如靜態程式碼檢查,效能測試等。
持續交付適用於幾乎任何對質量、交付速度和結果的可預測性有要求的低風險部署和釋出場景,包括嵌入式系統、web應用、移動應用等。開發者通過持續交付可以自動完成釋出過程,並且可以通過單擊按鈕隨時部署應用程式。
理論上講,持續交付可以滿足每日一次、每週一次等固定釋出頻率,或者滿足業務需求的任何頻率,但是,如果真的想獲得持續交付的好處,應儘早將應用部署到生產環境,以確保可以小批次釋出,並且發現問題後及時排除故障。
華為雲DevCould程式碼託管CodeHub是一個線上程式碼倉庫,為開發者提供基於Git的線上程式碼託管服務,包括程式碼克隆/提交/推播/比較/合併/Code Review等功能。
開發人員可將程式碼提交至CodeHub。
在「編譯構建」服務中,使用者可根據自己的程式語言,程式設計環境,自主設定所需的構建步驟,並對指定的程式碼倉庫進行編譯構建。
當然華為雲DevCloud的編譯構建功能支援持續整合:提交程式碼觸發執行編譯構建。
部署功能與編譯構建在使用方面類似,都是根據自己的業務場景設定相應的部署任務,任務設定完成後,可根據業務需要,執行部署任務。
之前提到了持續交付流水線,華為雲DevCloud流水線功能可以將已經設定好構建,部署等服務串聯到一起,實現一鍵部署。