主頁 > 軟體設計 > 搭建DevOps模式的專案

搭建DevOps模式的專案

2020-09-12 19:03:39 軟體設計

在后端的開發領域,各類開發框架都已經很多,在開發專案時可以根據不同的需要和需求選擇合適的開發框架,然而在需要開發一個完善的工程化專案時,僅僅一個后端開發框架是不夠的,還面臨著在對開發專案的快速迭代中進行測驗,部署,監控等問題,為了解決這些問題,DevOps的開發模式應運而生,

基于個人對DevOps的理解,搭建了一個基于Gin的開源后端專案來實踐下DevOps的各個概念:https://github.com/wanghaoxi3000/advproject,

DevOps是一個寬泛的概念,這個專案也只是拋磚引玉,在測驗環境下串聯起各個DevOps的基礎工具,存在的不足歡迎指出,一起學習和交流,

如何構建DevOps模式的專案

什么是DevOps呢,對DevOps比較官方的定義如下:

DevOps 集文化理念、實踐和工具于一身,可以提高組織高速交付應用程式和服務的能力,與使用傳統軟體開發和基礎設施管理流程相比,能夠幫助組織更快地發展和改進產品,這種速度使組織能夠更好地服務其客戶,并在市場上更高效地參與競爭,

可以說DevOps是一組程序、方法與系統的統稱,涉及到開發中的組織架構,開發工具,基礎架構等等方面,但它的一個核心便是強調通過各類自動化的工具來自動執行軟體交付和基礎架構更改流程,從而快速、頻繁且更可靠地構建、測驗和發布軟體,這里也將主要圍繞這個思想來構建DevOps的專案,

在這個基礎專案中,將主要圍繞如下部分的Devops實踐進行構建:

  • 持續集成:一種軟體開發實踐經驗,開發人員會定期將他們的代碼變更合并到一個中央存盤庫中,之后系統會自動運行構建和測驗操作,
  • 持續交付:自動構建和測驗代碼更改,并為將其發布到生產環境做好準備,實作對持續集成的擴展,
  • 基礎設施即代碼:使用基于代碼的工具來連接基礎設施,并且能夠以處理應用程式代碼的方式來處理基礎設施,基礎設施和服務器由代碼進行定義,
  • 監控和日志記錄:組織對各項指標和日志進行監控,以了解應用程式和基礎設施性能如何影響其產品的最終用戶體驗,

整個專案的開發流程如下:

開發工具及環境

要完成從開發到部署的一系列的流程,當然也少不了各種自動化工具及環境的支持,本專案所使用的環境如下:

  1. 代碼開發環境Go 1.13
  2. Github賬戶
  3. 容器倉庫,本專案使用騰訊云容器服務
  4. Jenkins 2.190
  5. Kubernetes 本專案使用基于k8s v1.16.1的三節點集群

DevOps專案開發流程

通過advproject這個基于Gin的后端專案的代碼更新、提交、完成對專案的自動化測驗、打包、部署的流程,

后端專案

advproject專案主要包含了如下部分:

  • 介面檔案 swag
  • 日志 zap
  • 配置 godotenv
  • docker容器化檔案 Dockerfile
  • Jenkinsflie Jenkinsfile
  • Kubernetes部署檔案 deployment-template.yaml

整個代碼的結構如下

.
├── Dockerfile                  // Docker鏡像打包檔案
├── Jenkinsfile                 // Jenkins CI 定義
├── README.md
├── api
│   └── status.go               // 運行狀態介面
├── config
│   ├── base.go                 // 基礎配置
│   └── init.go                 // 配置模塊初始化
├── deployment-template.yaml    // Kubernetes部署模板檔案
├── docs                        // swag 介面檔案
│   ├── docs.go
│   ├── swagger.json
│   └── swagger.yaml
├── go.mod
├── go.sum
├── main.go
├── serializer
│   └── common.go               // 介面格式定義
├── server
│   └── router.go               // 路由
├── test
│   └── status_test.go          // 測驗代碼
└── util
    └── logger.go               // 日志模塊

Jenkins CI配置

在代碼有更新時,提交代碼到Github后,Jenkins會收到代碼Github推送通知,拉取代碼并讀取代碼中的Jenkinsfile檔案來運行指定的流程,

可通過如下命令docker來快速運行一個Jenkins,為了在Jenkins容器中使用docker命令,將docker命令映射到了容器中,同時指定以root身份來運行容器,

docker run --name=jenkins_lts -d -u root -v jenkins_home:/var/jenkins_home -v /var/run/docker.sock:/var/run/docker.sock -v $(which docker):/bin/docker -p 8080:8080 -p 50000:50000 -e JAVA_OPTS=-Duser.timezone=Asia/Shanghai jenkins/jenkins:lts

在Jenksin容器啟動完成并成功登陸后,可以點擊主界面右下角的Jenkins 中文社區鏈接,然后更新中心鏡像設定為國內源,加快插件的下載速度,

環境配置

本專案中主要使用到這些Jenkins插件,可以在插件管理頁面中搜索安裝:

  • Blue Ocean 方便和Pipeline搭配使用
  • Kubernetes Cli Plugin 通過kubectl操控k8s集群

在執行部署的推送鏡像、通知等程序中,需要使用到不方便暴露在代碼中的密鑰,如何在Jenkinsfile中使用這些密鑰呢?可以提前在Jenkins的憑據管理中錄入這些密鑰,Jenkinsfile中以變數的方式進行呼叫,這里配置了如下的憑證:

  • tcloud-docker-reg 鏡像倉庫登錄密鑰
  • kubctl-config kubectl密鑰
  • PUSH_KEY 基于Server醬通知推送的密鑰

建立專案

通過Jenkinsfile檔案以代碼宣告的方式來定義持續集成的流程,需要在Jenkins中建立一個 Pipeline流水線專案,

選擇新建任務,輸入任務名建立一個流水線專案:

General選項卡中勾選GitHub專案,并填入專案地址:

在代碼推送后,使用GitHub的webhook功能推送代碼更新訊息,需要在構建觸發器中勾選GitHub hook trigger for GITScm polling

此后還需要在GitHub的代碼專案中配置webhook推送更新的地址,相關文章已有很多,這里就不再累述了,

最后,在流水線配置中填入代碼地址:

指定分支中默認為*/master,表示拉取master分支的更新,如果想要拉取指定tag的代碼,可以按這樣的格式來配置:+refs/tags/*:refs/remotes/origin/tags/*

運行一下,可以看見Jenkins開始啟動并運行了,

通過Blue Ocean,可以看見更詳細的運行圖,

推送結果

推送的結果將通過Server醬推送到系結的微信中,Server醬是一個很方便的微信推送服務,只需要系結下GitHub賬戶,之后請求對應地址即可向微信推送訊息,推送的資訊包含本次集成的結果和代碼更新的記錄,集成結果在Jenkinsfile中可以通過${currentBuild.result}來獲取,代碼更新記錄Jenkins沒有對應的變數,可以通過運行git log --pretty=format:\'%h - %an,%ar : %s\' --since=\'1 hours\' | head -n 1來獲取代碼最近一次的變更記錄,

部署到Kubernetes

專案每次更新完成,同通過Jenkins拉取代碼測驗無誤后,將會把專案打包成鏡像并以build-${BUILD_NUMBER}作為tag,并推送到騰訊云的私有鏡像倉庫中,${BUILD_NUMBER}是Jenkins運行任務時的環境變數,表示運行本次集成任務的序號,之后以專案中deployment-template.yaml為模板,替換對應變數后部署到k8s集群上,

Jenkins pipeline 執行完成后登錄集群節點,運行kubectl get pods,可以看到剛剛部署上的專案,已全處于了Running狀態了,

NAME                          READY   STATUS    RESTARTS   AGE
advproject-6f5d4d7d5d-pwmrp   1/1     Running   0          33s
advproject-6f5d4d7d5d-zscz2   1/1     Running   0          19s

為了便于測驗,快速訪問集群中的服務,可以按如下配置啟動一個NodePort的Service,將Pod的埠暴露出來,

apiVersion: v1
kind: Service
metadata:
  name: advproject-svc
spec:
  type: NodePort
  ports:
  - port: 3000
    targetPort: 3000
    protocol: TCP
  selector:
    app: advproject

通過kubectl get service可以看到NodePode分配的埠號為30942:

NAME             TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)          AGE
advproject-svc   NodePort    10.110.152.165   <none>        3000:30942/TCP   25d

在節點上運行curl localhost:30942/api/v1/hostname,可以查看到專案對應的hostname,由于部署的Deployment檔案中設定的replicas: 2,專案部署的節點數為2,請求的hostname也會隨機出現兩種,

日志監控

進入k8s的dashboard,在側邊欄選擇容器組,可以看見運行專案的兩個容器的,點擊日志可以在網頁中分別查看每個容器的控制臺日志,這里可以看到剛剛請求hostname介面的日志,以及k8s在定時請求status介面進行健康檢查,
容器日志

為了更好的收集和分析日志,這里將通過k8s的ELK插件,來統一收集日志,克隆k8s對應版本的代碼,使用k8s專案/cluster/addons/fluentd-elasticsearch目錄下的示例代碼,使用kubectl apply -f .命令可以快速部署一個ELk插件,

部署完成后,登錄kibana,創建一個默認的 logstash-* pattern,
index

稍等一會,就可以Discover選單下看到ElasticSearch logging中匯聚的日志,在Filters中搜索Gin,可以看到本專案的日志了,
日志

總結

至此,一個以DevOps模式的專案開發流程便大致完成了,當然這個程序也還有很多可以繼續完善的地方,比如生成更詳細的代碼測驗報表、使用kibana生成日志報表、監測代碼中的錯誤日志并報警等等,通過DevOps,將開發、測驗、運維這些步驟緊密聯系了起來,使得構建、測驗、發布軟體能夠更加地快捷、頻繁和可靠,除了這些技術和工具,DevOps也更需要組織中各個部門之間的進行良好的溝通、協作與整合,在實際開發中,需要通過各個部門的分工合作,開發人員撰寫業務和單元測驗代碼;測驗人員設計測驗用例,關注代碼測驗報告;運維人員設計Kubernetes部署模板,監控系統及日志資料,這樣才能發揮DevOps的最大效力,更好地為客戶服務并在市場中更有競爭力,

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/16275.html

標籤:架構設計

上一篇:UML之三、建模元素(2)

下一篇:分布式協調與同步之分布式選舉

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more