gitops 之a(chǎn)rgocd

封面圖片

簡介:本文旨在通過實(shí)際的例子讓大家感受argocd如何實(shí)現(xiàn)gitops的CD 管理,幫助你快速的在實(shí)際生產(chǎn)環(huán)境中快速使用起來argocd。

本文實(shí)踐全是基于其argocd 官方網(wǎng)址以及arogcd github

系列文章同步更新中:

argocd的secret管理之SealedSecret:在git里面加密敏感配置
argocd告警管理之notification服務(wù):讓你第一時(shí)間得到argocd app的狀態(tài)信息
argocd藍(lán)綠/金絲雀發(fā)布之rollout: 快速方便的啟用基于gitops的藍(lán)綠/金絲雀發(fā)布
gitops之a(chǎn)rgocd

一,argocd安裝部署

1,首先你的有個(gè)k8s集群,關(guān)于搭建k8s集群還是比較簡單,可以自行解決哈,如果用kubeadm搭建也可以參考 我的github地址.
2, 安裝argocd
如果你應(yīng)用于你的生產(chǎn)考慮HA等點(diǎn)擊我了解詳細(xì)的官方安裝yaml

快速簡單安裝使用如下命令:

kubectl create namespace argocd
kubectl apply -n argocd -f https://raw.githubusercontent.com/argoproj/argo-cd/stable/manifests/install.yaml

3,安裝完成后如下:
3.1


安裝后的deployment

3.1.1
argocd-application-controller: controller 是argocd的處理器,主要是幫你管理你的k8s 資源,基本上你之前用kubectl 做的的操作它都集成了,operater的controller。
當(dāng)你的app過多時(shí),可以通過修改啟動(dòng)參數(shù)提高其處理能力如下:

修改argocd-application-controller的配置清單 deployment

controller uses two separate queues to process application reconciliation (milliseconds) and app syncing (seconds). Number of queue processors for each queue is controlled by --status-processors (20 by default) and --operation-processors (10 by default) flags. Increase number of processors if your Argo CD instance manages too many applications. For 1000 application we use 50 for --status-processors and 25 for --operation-processors

argocd-dex-server: 認(rèn)證token服務(wù),為后面實(shí)現(xiàn)gitlab登錄等。高可用版本時(shí)候不支持多pod,只能單個(gè)pod。

The argocd-dex-server uses an in-memory database, and two or more instances would have inconsistent data

argocd-redis: 緩存所用。
argocd-repo-server: 這個(gè)服務(wù)主要功能是去git 你的gitlab 公有/私有倉庫到argocd-repo-server這個(gè)pod里面最后讓argocd進(jìn)行相應(yīng)的kubectl 操作。高可用建議:多個(gè)pod來處理多個(gè)應(yīng)用在一個(gè)repo的場景。repo管理建議:repo里面主要存放配置管理文件以免消耗過多的本地空間,因?yàn)?strong>argocd-repo-server會(huì)拉取你的repo 到本地。如果repo實(shí)在是太大的話,建議掛載磁盤到該服務(wù)的/tmp目錄。
argocd-server: argocd 的前后端服務(wù),整個(gè)web服務(wù)。里面還內(nèi)置helm/kubectl 等工具,具體可以進(jìn)入到pod里面去查看。
3.2

安裝后的service

正如上圖所示我們將argocd-server 用nodeport的方式暴露出來以供我們訪問argocd的界面。值得注意的是需要我們自己去安裝清單文件里面去修改暴露的方式。

二,argocd界面使用

argocd 登錄界面
1, 登錄用戶名密碼admin/<argocd-pod-name>
2, 界面使用之settings

Argocd settings

2.1 Repositories:添加私有repo 地址,讓argocd 有權(quán)限去你的私人倉庫git pull代碼,注意ssk-key的權(quán)限最好是owner,因?yàn)樗还馐莋it clone 還有很多git的操作比如查看你的revision等。然后就是你的gitlab 的網(wǎng)絡(luò)最好是和argocd在一個(gè)內(nèi)網(wǎng)里面這樣會(huì)穩(wěn)定點(diǎn)。
添加成功的狀態(tài)

2.2 Clusters: cluster 功能主要是為了添加多kubernetes 集群管理支持的,這樣你只需要將argocd部署在一個(gè)k8s集群,然后通過cluster功能關(guān)聯(lián)新的k8s集群,即可將你的應(yīng)用部署到相關(guān)連的多個(gè)集群上。
添加集群后的顯示

注意:目前不支持界面手動(dòng)添加cluster,只能通過命令行添加:
添加多個(gè)cluster之shell 代碼支持
總結(jié):
第一步: 按照官方文檔添加多cluster信任
第二步:

#列出你當(dāng)集群當(dāng)前添加過的信任的集群,類似kubectl config get-contexts
#所以前提是你先將你的待添加k8s集群加入到你的contexts里面。
argocd cluster add
##一切都準(zhǔn)備好了之后就可以用這個(gè)命令添加你的目標(biāo)機(jī)器到你的argocd server了
argocd cluster add <contenxt-name>

The above command installs a ServiceAccount (argocd-manager), into the kube-system namespace of that kubectl context, and binds the service account to an admin-level ClusterRole. Argo CD uses this service account token to perform its management tasks (i.e. deploy/monitoring).

添加成功的輸出

最后你就可以在創(chuàng)建app的時(shí)候選擇需要部署的目標(biāo)集群了。
2.2.1 如何添加rancher RKE 到argocd管理?
詳細(xì)可以訪問 最佳解決方案
如果不能訪問,請按照如下secret配置好rancher的訪問。需要的token 和ca你均能在rancher kubeconfig里面找到。BTW ,ca.pem需要base64 -d回來。

apiVersion: v1
kind: Secret
metadata:
  name:  <secret 的名字:mysql-cluster-secret>
  labels:
    argocd.argoproj.io/secret-type: cluster
  namespace: argocd
type: Opaque
stringData:
  name: <argocd 設(shè)置界面顯示名字>
  server: <rancher rke endpoint> https://<IP>/k8s/clusters/c-27fv2
  config: |
      {
        "bearerToken": "<token>",
        "tlsClientConfig": {
          "insecure": false,
          "caData": "<ca.pem>"
                         }
      }

2.3 Projects: settings之project管理,project 主要用來做權(quán)限限制的,我們將不同的app的app放在不同的project以方便我們區(qū)分和管理,project可以限制所管理的app部署時(shí)間通過sync windows、限制app部署的集群/命名空間等、以及那個(gè)APP才能部署。后期做相應(yīng)的權(quán)限控制比如指定某個(gè)用戶只能對(duì)某個(gè)project里面的app進(jìn)行sync等操作。
2.3.1 創(chuàng)建project可以通過界面直接創(chuàng)建也可以通過以下yaml創(chuàng)建:

project 管理界面

#############project here
apiVersion: argoproj.io/v1alpha1
kind: AppProject
metadata:
  name: <project name here>
  namespace: argocd
spec:
##部署窗口設(shè)置,如下
  syncWindows:
  - kind: allow
    ##+8 utc  eveyday 9-11 can be sync
    schedule: '0 1 * * *'
    duration: 12h
    applications:
    - '*'
    manualSync: false
  # Project description
  description: <project 描述方便維護(hù)>
  # Allow manifests to deploy from any Git repos
  sourceRepos:
##限制你project能git的 repo
  - 'https://github.com/keanlee/kubernetes_deploy.git'
  # Only permit applications to deploy to the guestbook namespace in the same cluster
  destinations:
  - namespace: <對(duì)命名空間進(jìn)行限制>
    server: https://<ip addr>:6443 ##對(duì)集群進(jìn)行限制,限制app只能部署到指定集群
  # Enables namespace orphaned resource monitoring.
  orphanedResources:   ##這個(gè)功能主要是啟動(dòng)對(duì)非argocd管理的k8s 資源進(jìn)行管理(刪除 修改配置等)
    warn: true

以上操作均可通過界面操作如下圖:


project豐富的界面操作

啟用orphanedResources后在app界面的開關(guān)

上面這個(gè)選項(xiàng)勾選后會(huì)利用argocd強(qiáng)大的界面講此app 同一個(gè)namespace下的所以資源羅列出來:


通過虛實(shí)結(jié)合的方式顯示出當(dāng)前被argocd管理的和未被管理的資源

通過該界面你不管能看到這些未被argocd管理的資源而且還能對(duì)其進(jìn)行修改。
sync window 可以限制什么時(shí)間才能部署你project里面的app
2, 界面使用之a(chǎn)pp管理

2.1 創(chuàng)建app:

通過界面創(chuàng)建app

通過簡單的界面提醒我們就能非??旖莸膭?chuàng)建出一個(gè)我們的app來,下面如何通過yaml來創(chuàng)建:
yaml 自動(dòng)化創(chuàng)建app


##因?yàn)閍rgocd 是一個(gè)operator實(shí)現(xiàn),所以我們可以通過如下命令進(jìn)行查看和修改:
#kubectl get Application -n gitops
NAME    AGE
nginx   22m
argocd強(qiáng)大的界面顯示

2.2 配置管理工具支持:
2.2.1 原始的yaml支持:


原始文件的支持,只有后綴是yaml的都會(huì)被同步

2.2.2 helm等工具的支持
helm是目前比較推薦的上argocd的方式,通過不同的values 文件區(qū)分出不同的環(huán)境,從而達(dá)到一套部署模板適用于多個(gè)環(huán)境。不同的values可以在創(chuàng)建app的時(shí)候通過參數(shù)指定:

...
 helm:
   valueFiles:
   - values-producation.yaml
...

2.3 同步方式選擇:
2.3.1 手動(dòng)同步,這種方式就是創(chuàng)建了app后需要每次在界面點(diǎn)擊 sync按鈕方能從你的git 倉庫中拉取最新的部署代碼進(jìn)行操作。
2.3.2 自動(dòng)同步:


自動(dòng)同步啟用中
#代碼中啟用
...
syncPolicy:
  automated:
    prune: true  #是否隨著部署文件刪除回收資源,例如你有個(gè)service的配置,啟用后當(dāng)你在gitlab里面注釋或刪除了該配置代碼后,argocd會(huì)將其對(duì)應(yīng)的service資源刪除
    selfHeal: true #自愈功能,時(shí)刻保持和git倉庫同步,例如有人通過k8s dashboad改了你的一個(gè)配置,這個(gè)功能啟用后快速?zèng)_掉其修改的配置,通過k8s dashboard刪除該資源也一樣會(huì)快速創(chuàng)建。包括但不限于deployment。
...

總結(jié)

以上就是關(guān)于argocd的基本使用,更多詳細(xì)的使用請移步官方網(wǎng)站。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,563評(píng)論 6 544
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,694評(píng)論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 178,672評(píng)論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,965評(píng)論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,690評(píng)論 6 413
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 56,019評(píng)論 1 329
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,013評(píng)論 3 449
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,188評(píng)論 0 290
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,718評(píng)論 1 336
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,438評(píng)論 3 360
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,667評(píng)論 1 374
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,149評(píng)論 5 365
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,845評(píng)論 3 351
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,252評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,590評(píng)論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,384評(píng)論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,635評(píng)論 2 380