CI/CD和 DevOps還在傻傻分不清嗎?今日一文讓你通透

来源:https://www.cnblogs.com/jiagooushi/archive/2022/09/16/16699915.html
-Advertisement-
Play Games

基本概念 持續集成 (Continuous Intergration) ​ 持續集成的重點在於構建編譯及測試,開發人員每天要提交很多次代碼到分支,在分支合併到主幹前,需要通過編譯和測試識別出問題。持續集成的流程就是通過自動化的構建(主要是構建編譯、自動化測試)來驗證,從而儘早地發現集成錯誤。 持續集 ...


file

基本概念

持續集成

(Continuous Intergration)

​ 持續集成的重點在於構建編譯及測試,開發人員每天要提交很多次代碼到分支,在分支合併到主幹前,需要通過編譯和測試識別出問題。持續集成的流程就是通過自動化的構建(主要是構建編譯、自動化測試)來驗證,從而儘早地發現集成錯誤。

持續集成的核心意義:通過自動化測試儘早的發現代碼的問題。

file

持續交付

(Continuous Delivery):

​ 持續交付指的是將產品儘可能快的發佈上線的過程。持續交付是在持續集成基礎上的擴展,也就是說除了自動化編譯、自動化測試,為了儘快上線我們還需要自動化發佈流程,整個流程實現後,根據實際需要,可以周期性的進行產品上線發佈,上線方式為人工點擊部署實現快速上線。部署環境的先後部署順序,一般在公司都是開發環境、測試環境、預發佈環境(類生產環境)和正式生產環境,如果代碼在預發佈環境測試通過,那麼就可通過手動的方式部署生產環境實現上線的目的。

持續交付的核心意義:儘快的將最終的產品發佈到線上環境,給用戶使用。持續交付是每個企業追求的目標,我們常說的CI/CD里的CD一般指的就是持續交付。

file

持續部署

(Continuous Deployment):

​ 持續部署就是在持續交付的基礎上,將編譯、測試、打包部署到生產環境的過程做成自動化。

​ 持續部署的核心意義:持續的將迭代的需求自動化的方式部署到生產環境。一般來說,非生產環境的持續部署基本都能實現。但生產環境的持續部署並不是每個企業都能做到,主要原因是受限於各種系統功能依賴、自動化測試不完善等因素,自動化一旦部署到生產,將可能造成嚴重生產事故。

file

說明:無論是持續集成、持續交付還是持續部署,如果要實現整個流程,基本上離不開CI伺服器。

持續集成

特點
  • 快速定位錯誤,測試環節可以及時暴露問題;
  • 避免大幅度偏離主幹,藉助統一的代碼庫;
  • 減少不必要的成本投入,可以自動化解決的重覆乏味的事情,沒必要浪費人力和時間;
工作流程

file

工作階段

持續集成工作流程大體包括這麼幾個階段:

  • 初始化CI流程

    基本的CI流程的配置,比如腳本、定時任務等。

  • 拉取最新代碼

    從源碼倉庫拉取最新代碼到構建伺服器磁碟上。

  • 構建

    一般源碼倉庫自包含構建,可通過配置的腳本觸發執行構建。比如Java的構建一般基於Maven或Gradle。

  • 執行測試

    測試階段一般包含單元測試和集成測試。Java中的單元測試常指JUnit。

  • 結果處理

    CI流程執行的最後結果要麼是成功,要麼是失敗,結果需要通知給對應的人員,一般的通知方式有郵件、釘釘、簡訊。

集成工具
  • Travis CI

  • Bamboo

  • TeamCity

  • CircleCI

  • Gitlab CI

  • Jenkins

DevOps

概念

DevOps這個詞,其實就是Development(開發)和Operation(運維)兩個詞的組合。

​ DevOps 不是一項技術,也不是一套流程和方法論,更不是一套簡單的工具產品。DevOps的維基百科定義是這樣的:DevOps是一組過程、方法與系統的統稱,用於促進開發、技術運營(運維)和質量保證(QA)部門之間的溝通、協作與整合。

​ 通過實踐 DevOps,可以將開發、測試、運維之間的工作串聯起來,以持續構建、自動化測試、持續發佈為目標,將所有流程全部自動化,最大化減少了重覆性的人力投入。同時,基礎環境的自動化構建也降低了由於人的原因帶來的意外風險。下圖為DevOps所包含的流程:

file

​ DevOps 這個詞是Patrick Debois 於2009 年創造的。出生於比利時的Patrick 先生曾經是一名苦悶的IT 咨詢師,飽受開發和運維相互割裂及傷害之苦。2009 年他參加了一個技術大會,在會上聽了名為10+ Deploys Per Day: Dev and Ops Cooperation at Flickr 的演講,深受啟發,並創造了DevOps 這個詞。

​ 目前,DevOps處於高速增長的階段。尤其是在大企業中,DevOps受到了廣泛的歡迎。越大的企業,越喜歡DevOps。包括Adobe、Amazon、Apple、Airbnb、Ebay、Etsy、Facebook、LinkedIn、Netflix、NASA、Starbucks、Walmart、Sony等公司,都在採用DevOps。

工具鏈

​ 由於DevOps是一種跨職能的工作模式,因此實踐過程需要使用不同的工具集(被稱為 "工具鏈"),而不是單一的工具集。這些工具鏈應該符合以下一個或多個類別,這些類別反映了開發和交付過程中的關鍵環節:

  • 編碼---代碼開發和審查、源代碼管理工具、代碼合併

  • 構建---持續集成工具,構建狀態

  • 測試---持續測試工具,提供快速、及時的業務風險反饋

  • 發佈---變更管理、發佈審批、發佈自動化

  • 配置---基礎設施配置和管理,基礎設施作為代碼工具的基礎設施

  • 監控---應用性能監控、終端用戶體驗

DevOps生態圈工具鏈圖:
file

常用工具

​ DevOps 需要要通過技術工具鏈完成持續集成、持續交付、用戶反饋和系統優化的整合。工具鏈包括版本控制&協作開發工具、自動化構建和測試工具、持續集成&交付工具、部署工具、維護工具、監控,警告&分析工具等等。

  • 版本控制&協作開發:GitHub、GitLab、BitBucket、SubVersion、Coding、Bazaar
  • 自動化構建和測試:Apache Ant、Maven 、Selenium、PyUnit、QUnit、JMeter、Gradle、PHPUnit
  • 持續集成&交付:Jenkins、Capistrano、BuildBot、Fabric、Tinderbox、Travis CI、flow.ci Continuum、LuntBuild、CruiseControl、Integrity、Gump、Go
  • 容器平臺:Docker、Rocket、Ubuntu(LXC)、第三方廠商如(AWS/阿裡雲)
  • 配置管理:Chef、Puppet、CFengine、Bash、Rudder、Powershell、RunDeck、Saltstack、Ansible
  • 微服務平臺:OpenShift、Cloud Foundry、Kubernetes、Mesosphere
  • 服務開通:Puppet、Docker Swarm、Vagrant、Powershell、OpenStack Heat
  • 日誌管理:Logstash、CollectD、StatsD
  • 監控,警告&分析:Nagios、Ganglia、Sensu、zabbix、ICINGA、Graphite、Kiban
DevOps的目標
  • 更快的上市時間

  • 提高部署頻率

  • 更短的修複時間

  • 降低發佈失敗率

  • 更快的平均恢復時間

總結來說DevOps的目標是最大限度地提高運營流程的可預測性、效率、安全性和可維護性。

小結

兩者關係
  • 由DevOps的流程和工具鏈我們可以得知,DevOps 是持續集成思想的延伸

  • 持續集成/部署是 DevOps 的技術核心,在沒有自動化測試、持續集成/部署之下,DevOps就是空中樓閣。

本文由傳智教育博學谷教研團隊發佈。

如果本文對您有幫助,歡迎關註點贊;如果您有任何建議也可留言評論私信,您的支持是我堅持創作的動力。

轉載請註明出處!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 我的設計模式之旅,本節使用抽象工廠模式實現阿迪達斯、耐克品牌服飾生產,分別用C#跟Golang實現。對抽象方法模式進行了細緻的介紹。 ...
  • 享元模式(Flyweight Pattern)主要用於減少創建對象的數量,以減少記憶體占用和提高性能。這種類型的設計模式屬於結構型模式,它提供了減少對象數量從而改善應用所需的對象結構的方式。 ...
  • 摘要:別名分析是編譯器理論中的一種技術,用於確定存儲位置是否可以以多種方式訪問。 本文分享自華為雲社區《編譯器優化那些事兒(6):別名分析概述》,作者:畢昇小助手。 1.簡介 別名分析是編譯器理論中的一種技術,用於確定存儲位置是否可以以多種方式訪問。如果兩個指針指向相同的位置,則稱這兩個指針為別名。 ...
  • 《阿裡巴巴Java開發手冊》的願景是碼出高效,碼出質量。它結合作者的開發經驗和架構歷程,提煉阿裡巴巴集團技術團隊的集體編程經驗和軟體設計智慧,濃縮成為立體的編程規範和最佳實踐 《碼出高效:Java 開發手冊》源於影響了全球250萬名開發工程師的《阿裡巴巴Java開發手冊》,作者靜心沉澱,對Java規... ...
  • 目錄 一.OpenGL ES 版本 二.嵌入式設備的 OpenGL ES 版本 三.不同 OpenGL ES GLSL 腳本區別 1.OpenGL ES 1.0 不支持腳本 2.OpenGL ES 2.0 GLSL 腳本 3.OpenGL ES 3.0 GLSL 腳本 四.OpenGL ES 和 O ...
  • 首先推薦《高性能 MySQL》,這本書是 MySQL 領域的經典之作,擁有廣泛的影響力。不但適合資料庫管理員(DBA)閱讀,也適合開發人員參考學習。不管是資料庫新手還是專家,都能從本書中有所收穫。 其次如果你對 MySQL 的內部原理有興趣的話,可以看一下這本書《MySQL 技術內幕:InnoDB ... ...
  • 如果你是準備自學Python或者正在學習,你應該能用得上: ① Python所有方向的學習路線圖,清楚各個方向要學什麼東西 ② 80多節Python課程視頻,涵蓋必備基礎、爬蟲和數據分析 ③ 100多個Python項目源碼,學習不再是只會理論 ④ 龍叔寫的獨家Python圖文教程,手機也能學習 ⑤ ...
  • 前言 嗨嘍,大家好呀~這裡是愛看美女的茜茜吶 又到了學Python時刻~ 第三方模塊: requests >>> pip install requests 如果安裝python第三方模塊: win + R 輸入 cmd 點擊確定, 輸入安裝命令 pip install 模塊名 (pip instal ...
一周排行
    -Advertisement-
    Play Games
  • 最近做項目過程中,使用到了海康相機,官方只提供了C/C++的SDK,沒有搜尋到一個合適的封裝了的C#庫,故自己動手,簡單的封裝了一下,方便大家也方便自己使用和二次開發 ...
  • 前言 MediatR 是 .NET 下的一個實現消息傳遞的庫,輕量級、簡潔高效,用於實現進程內的消息傳遞機制。它基於中介者設計模式,支持請求/響應、命令、查詢、通知和事件等多種消息傳遞模式。通過泛型支持,MediatR 可以智能地調度不同類型的消息,非常適合用於領域事件處理。 在本文中,將通過一個簡 ...
  • 前言 今天給大家推薦一個超實用的開源項目《.NET 7 + Vue 許可權管理系統 小白快速上手》,DncZeus的願景就是做一個.NET 領域小白也能上手的簡易、通用的後臺許可權管理模板系統基礎框架。 不管你是技術小白還是技術大佬或者是不懂前端Vue 的新手,這個項目可以快速上手讓我們從0到1,搭建自 ...
  • 第1章:WPF概述 本章目標 瞭解Windows圖形演化 瞭解WPF高級API 瞭解解析度無關性概念 瞭解WPF體繫結構 瞭解WPF 4.5 WPF概述 ​ 歡迎使用 Windows Presentation Foundation (WPF) 桌面指南,這是一個與解析度無關的 UI 框架,使用基於矢 ...
  • 在日常開發中,並不是所有的功能都是用戶可見的,還在一些背後默默支持的程式,這些程式通常以服務的形式出現,統稱為輔助角色服務。今天以一個簡單的小例子,簡述基於.NET開發輔助角色服務的相關內容,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 第3章:佈局 本章目標 理解佈局的原則 理解佈局的過程 理解佈局的容器 掌握各類佈局容器的運用 理解 WPF 中的佈局 WPF 佈局原則 ​ WPF 視窗只能包含單個元素。為在WPF 視窗中放置多個元素並創建更貼近實用的用戶男面,需要在視窗上放置一個容器,然後在這個容器中添加其他元素。造成這一限制的 ...
  • 前言 在平時項目開發中,定時任務調度是一項重要的功能,廣泛應用於後臺作業、計劃任務和自動化腳本等模塊。 FreeScheduler 是一款輕量級且功能強大的定時任務調度庫,它支持臨時的延時任務和重覆迴圈任務(可持久化),能夠按秒、每天/每周/每月固定時間或自定義間隔執行(CRON 表達式)。 此外 ...
  • 目錄Blazor 組件基礎路由導航參數組件參數路由參數生命周期事件狀態更改組件事件 Blazor 組件 基礎 新建一個項目命名為 MyComponents ,項目模板的交互類型選 Auto ,其它保持預設選項: 客戶端組件 (Auto/WebAssembly): 最終解決方案裡面會有兩個項目:伺服器 ...
  • 先看一下效果吧: isChecked = false 的時候的效果 isChecked = true 的時候的效果 然後我們來實現一下這個效果吧 第一步:創建一個空的wpf項目; 第二步:在項目裡面添加一個checkbox <Grid> <CheckBox HorizontalAlignment=" ...
  • 在編寫上位機軟體時,需要經常處理命令拼接與其他設備進行通信,通常對不同的命令封裝成不同的方法,擴展稍許麻煩。 本次擬以特性方式實現,以兼顧維護性與擴展性。 思想: 一種命令對應一個類,其類中的各個屬性對應各個命令段,通過特性的方式,實現其在這包數據命令中的位置、大端或小端及其轉換為對應的目標類型; ...