亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

在?k8s?中部署Jenkins的實(shí)踐指南(最新推薦)

 更新時(shí)間:2025年03月07日 11:02:51   作者:明明跟你說過  
本文介紹了在Kubernetes(K8s)中部署Jenkins的方法和步驟,包括準(zhǔn)備K8s集群、選擇Jenkins鏡像、創(chuàng)建存儲(chǔ)資源、賬號(hào)授權(quán)、部署Jenkins、創(chuàng)建Service以及訪問測(cè)試,Jenkins在K8s中的部署可以實(shí)現(xiàn)動(dòng)態(tài)資源管理、提高可靠性和容錯(cuò)能力、快速響應(yīng)變化和統(tǒng)一環(huán)境等優(yōu)勢(shì)

一、引言

1、Jenkins簡(jiǎn)介

Jenkins 是一個(gè)開源的自動(dòng)化服務(wù)器,主要用于持續(xù)集成(Continuous Integration, CI)和持續(xù)交付(Continuous Delivery, CD)。它由Sun Microsystems的前員工在2004年左右開發(fā),最初命名為Hudson。后來由于一些商標(biāo)爭(zhēng)議,項(xiàng)目改名為Jenkins,并且迅速成為構(gòu)建、測(cè)試和部署軟件項(xiàng)目的流行工具。

Jenkins的主要特點(diǎn)包括:

  • 持續(xù)集成與持續(xù)交付:Jenkins可以自動(dòng)監(jiān)控版本控制系統(tǒng)中的代碼變更,觸發(fā)構(gòu)建過程,運(yùn)行測(cè)試,并根據(jù)結(jié)果決定是否部署到生產(chǎn)環(huán)境。這有助于快速發(fā)現(xiàn)集成問題并縮短開發(fā)周期。
  • 插件生態(tài)系統(tǒng):Jenkins擁有龐大的插件庫(kù),支持幾乎所有現(xiàn)代軟件開發(fā)中可能用到的工具和技術(shù),比如Git、Maven、Gradle等。
  • 易于擴(kuò)展:由于Jenkins是基于Java編寫的,因此它非常靈活,用戶可以通過編寫自定義腳本或插件來擴(kuò)展其功能。
  • 分布式構(gòu)建:Jenkins支持通過“主從”架構(gòu)進(jìn)行分布式構(gòu)建,允許將構(gòu)建任務(wù)分配給多個(gè)節(jié)點(diǎn),以提高效率和資源利用率。
  • 圖形化界面:Jenkins提供了直觀的Web界面,使得配置和管理CI/CD流程變得簡(jiǎn)單。
  • Pipeline即代碼:Jenkins Pipeline是一個(gè)特性集,它允許用戶定義其CI/CD流程為代碼的形式(通常使用Groovy語(yǔ)言),這樣可以將其納入版本控制,并與其他團(tuán)隊(duì)成員共享。
  • 安全性:Jenkins提供了一些安全特性和認(rèn)證機(jī)制,確保只有授權(quán)用戶才能執(zhí)行特定的操作。
  • 社區(qū)和支持:作為一個(gè)開源項(xiàng)目,Jenkins有一個(gè)活躍的社區(qū),提供文檔、論壇討論以及第三方服務(wù)和支持。

2、k8s簡(jiǎn)介

Kubernetes(通常簡(jiǎn)寫為K8s)是一個(gè)開源平臺(tái),用于自動(dòng)化部署、擴(kuò)展和管理容器化的應(yīng)用程序。它最初由Google設(shè)計(jì)并開發(fā),并于2014年捐贈(zèng)給了云原生計(jì)算基金會(huì)(CNCF)。Kubernetes提供了強(qiáng)大的機(jī)制來管理分布式系統(tǒng)中的應(yīng)用,使其能夠在物理機(jī)或虛擬機(jī)集群上運(yùn)行。

特性

  • 自動(dòng)化容器編排:自動(dòng)重啟失敗的容器、替換和重新調(diào)度容器、水平擴(kuò)展容器等。
  • 自我修復(fù):如果某個(gè)節(jié)點(diǎn)故障,Kubernetes會(huì)自動(dòng)將該節(jié)點(diǎn)上的工作負(fù)載遷移到其他健康的節(jié)點(diǎn)上。
  • 橫向擴(kuò)展:通過簡(jiǎn)單的命令、用戶界面或者基于CPU使用情況自動(dòng)調(diào)整應(yīng)用的規(guī)模。
  • 服務(wù)發(fā)現(xiàn)與負(fù)載均衡:無需修改代碼即可實(shí)現(xiàn)服務(wù)之間的通信,Kubernetes為容器提供了自己的IP地址以及一個(gè)DNS名稱,并且可以負(fù)載均衡分配到容器上。
  • 自動(dòng)發(fā)布與回滾:逐步發(fā)布新的版本,同時(shí)監(jiān)視應(yīng)用健康狀況,如有問題則自動(dòng)回滾更改。
  • 密鑰與配置管理:讓您可以輕松地管理和分發(fā)密碼、OAuth令牌和其他敏感數(shù)據(jù),而無需重建鏡像。 

3、什么在k8s中部署Jenkins

在Kubernetes(簡(jiǎn)稱K8s)中部署Jenkins,可以帶來許多好處,尤其是對(duì)于那些需要高效、可擴(kuò)展和可靠的持續(xù)集成/持續(xù)交付(CI/CD)流程的企業(yè)或團(tuán)隊(duì)。

1. 動(dòng)態(tài)資源管理

想象一下,你有一家餐廳,有時(shí)候客人很多,有時(shí)候客人很少。如果每次客人都很多時(shí),你都需要臨時(shí)雇傭更多的服務(wù)員,而當(dāng)客人少時(shí)又得解雇他們,這樣不僅麻煩還浪費(fèi)資源。而在Kubernetes中部署Jenkins就像是有一個(gè)智能管理系統(tǒng),它可以根據(jù)當(dāng)前的工作負(fù)載自動(dòng)調(diào)整所需的服務(wù)員數(shù)量(即Jenkins構(gòu)建節(jié)點(diǎn))。當(dāng)有很多構(gòu)建任務(wù)時(shí),系統(tǒng)會(huì)自動(dòng)增加更多“服務(wù)員”來幫忙;反之,則減少“服務(wù)員”,從而更有效地利用資源。

2. 提高可靠性和容錯(cuò)能力

如果你的餐廳只有一個(gè)廚房,一旦這個(gè)廚房出現(xiàn)問題,整個(gè)餐廳就無法正常運(yùn)營(yíng)了。同樣,在傳統(tǒng)設(shè)置下,如果Jenkins主節(jié)點(diǎn)出現(xiàn)故障,所有的構(gòu)建任務(wù)都會(huì)停止。但在Kubernetes環(huán)境中,即使一個(gè)節(jié)點(diǎn)出問題,其他健康的節(jié)點(diǎn)可以立即接管工作,確保服務(wù)不間斷。

3. 快速響應(yīng)變化

假設(shè)你的餐廳突然接到一個(gè)大型宴會(huì)訂單,你需要快速準(zhǔn)備好額外的食物和服務(wù)。有了Kubernetes的幫助,Jenkins可以迅速擴(kuò)展其處理能力,就像瞬間增加了多個(gè)廚房一樣,以應(yīng)對(duì)突如其來的大量工作。完成后,還可以快速縮減規(guī)模,節(jié)省成本。

4. 統(tǒng)一環(huán)境

無論是在家中準(zhǔn)備食物還是在商業(yè)廚房里烹飪,保持一致的食譜和做法是非常重要的。將Jenkins部署到Kubernetes上,意味著你可以確保開發(fā)、測(cè)試和生產(chǎn)環(huán)境盡可能地相似,避免由于環(huán)境差異導(dǎo)致的問題。

二、準(zhǔn)備工作

1、準(zhǔn)備k8s集群

這里我們用的k8s版本為 1.23.1,大家也可以使用其他的k8s發(fā)行版本,如果還未安裝k8s請(qǐng)參考下面的文章。

《在Centos中搭建 K8s 1.23 集群超詳細(xì)講解》

《深度解析:Kubernetes 1.28.2集群安裝過程中的關(guān)鍵步驟》

2、Jenkins官方鏡像版本介紹

官方鏡像的推薦

Jenkins官方推薦使用 jenkinsci/blueocean 這個(gè)鏡像。與直接下載Jenkins的鏡像相比,Blue Ocean鏡像提供了更為現(xiàn)代和直觀的用戶界面,使得Jenkins的使用和管理變得更加容易。因此,對(duì)于新用戶或者希望簡(jiǎn)化Jenkins使用的用戶來說,推薦使用jenkinsci/blueocean鏡像。

鏡像版本標(biāo)簽

Jenkins官方鏡像在Docker Hub上提供了多個(gè)版本標(biāo)簽,以便用戶選擇。以下是一些常見的版本標(biāo)簽:

  • latest:表示最新版本的Jenkins,包括最新的功能和安全更新。然而,由于它是最新的版本,可能存在一些未知的問題或不穩(wěn)定因素。
  • lts:表示長(zhǎng)期支持版本的Jenkins,通常更穩(wěn)定且經(jīng)過更多的測(cè)試。它適合用于生產(chǎn)環(huán)境,因?yàn)樘峁┝烁嗟陌踩潞头€(wěn)定性修復(fù)。
  • 具體版本號(hào):例如2.401.1、1.24.1-bcc31d32159f等,表示特定版本的Jenkins。用戶可以根據(jù)自己的需求選擇特定的版本號(hào)。

3、Jenkins鏡像準(zhǔn)備

這里我們使用的Jenkins版本為2.410,鏡像我放在個(gè)人資源中了,大家也可以自行下載或使用其他的發(fā)行版本。

上傳至worker節(jié)點(diǎn)后,執(zhí)行下面的命令解壓

docker load -i jenkins-2.410.tar.gz

如果k8s版本大于1.23,則執(zhí)行下面的命令

ctr -n=k8s.io images import jenkins2.410

三、在Kubernetes中部署Jenkins

1、準(zhǔn)備存儲(chǔ)資源

我們準(zhǔn)備一個(gè)PVC,將Jenkins的數(shù)據(jù)持久化到當(dāng)中,以免pod漂移到其他節(jié)點(diǎn)后,歷史數(shù)據(jù)丟失。

下面簡(jiǎn)單介紹下如何創(chuàng)建PVC,更詳細(xì)的可以參考《k8s PV與PVC持久化存儲(chǔ)詳解與實(shí)際應(yīng)用分享》這篇文章

首先準(zhǔn)備一個(gè)NFS共享目錄

yum install nfs-utils -y
systemctl enable nfs --now
mkdir /data/jenkins -p
vim /etc/exports
# 添加下面的內(nèi)容
/data/jenkins *(rw,no_root_squash)
#保存、退出
exportfs -arv

創(chuàng)建一個(gè)名稱空間,用于部署Jenkins

kubectl create namespace jenkins-k8s

 編寫pv的yaml文件

apiVersion: v1
kind: PersistentVolume
metadata:
  name: jenkins-k8s-pv
spec:
  capacity:
    storage: 10Gi
  accessModes:
  - ReadWriteMany
  nfs:
    server: 192.168.40.181
    path: /data/jenkins
  • kind: PersistentVolume:定義了這個(gè)資源對(duì)象的類型是一個(gè)PersistentVolume(持久卷)。PersistentVolume是集群中的一段存儲(chǔ),它獨(dú)立于Pod的生命周期而存在。
  • metadata: 開始元數(shù)據(jù)部分,這里包含了資源對(duì)象的一些基本信息。
    • name: jenkins-k8s-pv:給這個(gè)PersistentVolume指定一個(gè)名稱,這里是jenkins-k8s-pv。在Kubernetes集群中,每個(gè)資源對(duì)象都需要一個(gè)唯一的名稱。
  • spec::開始定義PersistentVolume的具體規(guī)格和配置。
    • capacity::定義了這個(gè)持久卷的容量。
      • storage: 10Gi:指定了持久卷的存儲(chǔ)大小為10GiB(Gibibytes)。
  • accessModes::描述了持久卷可以被訪問的方式或模式。
  • - ReadWriteMany:表示這個(gè)卷可以被多個(gè)節(jié)點(diǎn)同時(shí)以讀寫方式掛載。其他可能的訪問模式包括ReadWriteOnce(只能由一個(gè)節(jié)點(diǎn)以讀寫方式掛載)和ReadOnlyMany(可以被多個(gè)節(jié)點(diǎn)以只讀方式掛載)。
  • nfs::指定了這個(gè)持久卷使用NFS(網(wǎng)絡(luò)文件系統(tǒng))作為其后端存儲(chǔ)機(jī)制。
    • server: 192.168.40.181:指定了NFS服務(wù)器的IP地址,這里是192.168.40.181。
    • path: /data/jenkins:指定了NFS服務(wù)器上共享的路徑,即實(shí)際存儲(chǔ)數(shù)據(jù)的位置,在這個(gè)例子中是/data/jenkins。

創(chuàng)建PV

kubectl  apply -f pv.yaml

編寫創(chuàng)建PVC的yaml文件

kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: jenkins-k8s-pvc
  namespace: jenkins-k8s
spec:
  resources:
    requests:
      storage: 10Gi
  accessModes:
  - ReadWriteMany

 創(chuàng)建PVC

kubectl apply -f  pvc.yaml

2、準(zhǔn)備賬號(hào)

創(chuàng)建sa賬號(hào)

kubectl create sa jenkins-k8s-sa -n jenkins-k8s

進(jìn)行RBAC授權(quán)

kubectl create clusterrolebinding jenkins-k8s-sa-cluster -n jenkins-k8s  --clusterrole=cluster-admin --serviceaccount=jenkins-k8s:jenkins-k8s-sa

3、部署Jenkins

準(zhǔn)備yaml文件

kind: Deployment
apiVersion: apps/v1
metadata:
  name: jenkins
  namespace: jenkins-k8s
spec:
  replicas: 1
  selector:
    matchLabels:
      app: jenkins
  template:
    metadata:
      labels:
        app: jenkins
    spec:
      serviceAccount: jenkins-k8s-sa
      containers:
      - name: jenkins
        image:  jenkins/jenkins:2.410
        imagePullPolicy: IfNotPresent
        ports:
        - containerPort: 8080
          name: web
          protocol: TCP
        - containerPort: 50000
          name: agent
          protocol: TCP
        resources:
          limits:
            cpu: 2000m
            memory: 2Gi
          requests:
            cpu: 500m
            memory: 512Mi
        livenessProbe:
          httpGet:
            path: /login
            port: 8080
          initialDelaySeconds: 60
          timeoutSeconds: 5
          failureThreshold: 12
        readinessProbe:
          httpGet:
            path: /login
            port: 8080
          initialDelaySeconds: 60
          timeoutSeconds: 5
          failureThreshold: 12
        volumeMounts:
        - name: jenkins-volume
          subPath: jenkins-home
          mountPath: /var/jenkins_home
      volumes:
      - name: jenkins-volume
        persistentVolumeClaim:
          claimName: jenkins-k8s-pvc

部署Jenkins

kubectl apply -f jenkins-deployment.yaml

4、創(chuàng)建Service

部署成功后,創(chuàng)建一個(gè)service,以供外部訪問

編寫yaml文件

apiVersion: v1
kind: Service
metadata:
  name: jenkins-service
  namespace: jenkins-k8s
  labels:
    app: jenkins
spec:
  selector:
    app: jenkins
  type: NodePort
  ports:
  - name: web
    port: 8080
    targetPort: web
    nodePort: 30089
  - name: agent
    port: 50000
    targetPort: agent

創(chuàng)建service

kubectl apply -f  service.yaml

5、訪問測(cè)試

瀏覽器輸入worker節(jié)點(diǎn)的IP+30089端口,如果顯示下面的頁(yè)面,證明部署成功

到此這篇關(guān)于在 k8s 中部署Jenkins的實(shí)踐指南的文章就介紹到這了,更多相關(guān)k8s部署Jenkins內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MinIO分布式文件存儲(chǔ)(從入門到飛翔)

    MinIO分布式文件存儲(chǔ)(從入門到飛翔)

    MinIO是一款高性能的分布式對(duì)象存儲(chǔ)系統(tǒng),兼容Amazon S3協(xié)議,具有輕量級(jí)、易部署、高可用和可擴(kuò)展性等優(yōu)勢(shì),它通過糾刪碼技術(shù)實(shí)現(xiàn)數(shù)據(jù)冗余與高容錯(cuò)性,適用于私有云存儲(chǔ)、大數(shù)據(jù)分析和靜態(tài)資源托管等場(chǎng)景,本文介紹MinIO分布式文件存儲(chǔ)的相關(guān)知識(shí),感興趣的朋友一起看看吧
    2025-03-03
  • Kubernetes實(shí)現(xiàn)CI與CD配置教程

    Kubernetes實(shí)現(xiàn)CI與CD配置教程

    這篇文章主要為大家介紹了基于Kubernetes實(shí)現(xiàn)CI與CD配置教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • 一文搞懂K8S中的NodeSelector

    一文搞懂K8S中的NodeSelector

    NodeSelector是Kubernetes用于指定Pod運(yùn)行節(jié)點(diǎn)的機(jī)制,通過節(jié)點(diǎn)上的標(biāo)簽(label)來選擇性地調(diào)度Pod,增加調(diào)度的靈活性和精確性,首先需要給節(jié)點(diǎn)打上標(biāo)簽,本文給大家介紹K8S中的NodeSelector,感興趣的朋友一起看看吧
    2024-10-10
  • 2022最新青龍面板對(duì)接機(jī)器人的詳細(xì)過程(傻妞對(duì)接onebot(oicq)協(xié)議實(shí)現(xiàn)機(jī)器人功能)

    2022最新青龍面板對(duì)接機(jī)器人的詳細(xì)過程(傻妞對(duì)接onebot(oicq)協(xié)議實(shí)現(xiàn)機(jī)器人功能)

    這篇文章主要介紹了2022最新青龍面板對(duì)接機(jī)器人的詳細(xì)過程(傻妞對(duì)接onebot(oicq)協(xié)議實(shí)現(xiàn)機(jī)器人功能),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • Jenkins打包、發(fā)布、部署完整驟記錄

    Jenkins打包、發(fā)布、部署完整驟記錄

    這篇文章主要介紹了Jenkins的基本概念,服務(wù)器環(huán)境檢查,以及如何安裝和配置Jenkins,包括安裝FTP服務(wù)、Maven、Git和Jenkins本身,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2025-03-03
  • K8s搭建Jenkins的詳細(xì)教程(附源代碼)

    K8s搭建Jenkins的詳細(xì)教程(附源代碼)

    Jenkins 是一個(gè)開源的自動(dòng)化服務(wù)器,主要用于持續(xù)集成和持續(xù)交付,這篇文章主要來和大家介紹一下如何在K8s中搭建Jenkins,有需要的可以了解下
    2025-03-03
  • k8s中secret的用法詳解

    k8s中secret的用法詳解

    secret用于加密pod訪問數(shù)據(jù)庫(kù)的用戶憑證,這篇文章主要介紹了k8s中secret的用法詳解,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-04-04
  • Kubernetes核心組件實(shí)戰(zhàn)解析之API?Server與Scheduler的生產(chǎn)級(jí)應(yīng)用指南

    Kubernetes核心組件實(shí)戰(zhàn)解析之API?Server與Scheduler的生產(chǎn)級(jí)應(yīng)用指南

    在Kubernetes集群中,kube-apiserver和kube-scheduler如同機(jī)場(chǎng)的塔臺(tái)控制系統(tǒng),一個(gè)負(fù)責(zé)全局通信調(diào)度,一個(gè)專注資源分配優(yōu)化,本文將深入解析這兩個(gè)核心組件在生產(chǎn)環(huán)境中的關(guān)鍵作用與實(shí)戰(zhàn)配置,需要的朋友可以參考下
    2025-03-03
  • k8s編排之DaemonSet知識(shí)點(diǎn)詳解

    k8s編排之DaemonSet知識(shí)點(diǎn)詳解

    這篇文章主要為大家介紹了k8s編排之DaemonSet知識(shí)點(diǎn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • 某集團(tuán)任意文件下載到虛擬主機(jī)getshell的方法

    某集團(tuán)任意文件下載到虛擬主機(jī)getshell的方法

    這篇文章主要介紹了某集團(tuán)任意文件下載到虛擬主機(jī)getshell的方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-01-01

最新評(píng)論