Jenkins 構建企業級 DevOps 容器云平臺2

#配置?jenkins?連接到我們存在的?k8s?集群

(1)訪問http://192.168.172.163:30002/configureClouds/新增一個云,在下拉菜單中選擇?kubernets?并添加

(2)填寫云?kubernetes?配置內容

kubernetes https://192.168.172.163:6443

如果是vip寫vip地址

?(3)測試?jenkins?和?k8s?是否可以通信

點擊連接測試,如果顯示?Connection test successful?或者顯示Connected to Kubernetes 1.20?說明測試成功,Jenkins?可以和?k8s?進行通信

kubectl get svc -n jenkins-k8s

NAME? ? ? ? ? ? ? TYPE? ? ? CLUSTER-IP? ? ? EXTERNAL-IP? PORT(S)? ? ? ? ? ? ? ? ? ? ? ? ? AGE

jenkins-service? NodePort? 10.109.88.145? <none>? ? ? ? 8080:30002/TCP,50000:30814/TCP? 108m

jenkins地址對應name

配置?k8s?集群的時候?jenkins?地址需要寫上面域名的形式,配置之后執行如下:?http://jenkins-service.jenkins-k8s.svc.cluster.local:8080?應用------>保存

#配置?pod-template

(1)配置?pod template

訪問?http://192.168.172.163:30002/configureClouds/

添加?Pod?模板------>Kubernetes Pod Template--->按如下配置

(2)在上面的?pod template?下添加容器 添加容器------>Container Template------>按如下配置------>

Docker?鏡像:使用?jenkins-jnlp.tar.gz?解壓出來的鏡像,把這個鏡像上傳到?k8s?的各?node?節 點,手動解壓:docker load -i jenkins-jnlp.tar.gz

解壓出來的鏡像是 god/jenkins-jnlp:v1

在每一個?pod template?右下腳都有一個?Advanced,點擊?Advanced,出現如下

在?Service Account?處輸入?jenkins-k8s-sa,這個?sa?就是我們最開始安裝?jenkins?時的?sa?(3)給上面的?pod template?添加卷

添加卷------>選擇?Host Path Volume

/var/run/docker.sock /var/run/docker.sock

/root/.kube /home/jenkins/.kube?上面配置好之后,應用------>保存

#添加?dockerhub?憑據

首頁------>系統管理----→管理憑據--→全局--→添加憑據

添加自己的dockerhub用戶

username:cadrcadr password:**** ID:dockerhub?描述:這個地方隨便寫 上面修改好之后選擇確定即可

#測試通過?Jenkins?發布代碼到?k8s?開發環境、測試環境、生產環境 在?k8s?的控制節點創建名稱空間:

63 ~]# kubectl create ns devlopment namespace

63 ~]# kubectl create ns production namespace

63 ~]# kubectl create ns qatest namespace

回到?jenkins?首頁:

pod模版 標簽列表對應pipeline

新建一個任務

------>輸入一個任務名稱處輸入?jenkins-variable-test-deploy------>流水線----- ->確定------>在?Pipeline script?處輸入如下內容

node('testhan') {

? ? stage('Clone') {

? ? ? ? echo "1.Clone Stage"

? ? ? ? git url: "https://github.com/cadrcadr/jenkins-sample.git"

? ? ? ? script {

? ? ? ? ? ? build_tag = sh(returnStdout: true, script: 'git rev-parse --short HEAD').trim()

? ? ? ? }

? ? }

? ? stage('Test') {

? ? ? echo "2.Test Stage"

? ? }

? ? stage('Build') {

? ? ? ? echo "3.Build Docker Image Stage"

? ? ? ? sh "docker build -t cadrcadr/jenkins-demo:${build_tag} ."

? ? }

? ? stage('Push') {

? ? ? ? echo "4.Push Docker Image Stage"

? ? ? ? withCredentials([usernamePassword(credentialsId: 'dockerhub', passwordVariable: 'dockerHubPassword', usernameVariable: 'dockerHubUser')]) {

? ? ? ? ? ? sh "docker login -u ${dockerHubUser} -p ${dockerHubPassword}"

? ? ? ? ? ? sh "docker push cadrcadr/jenkins-demo:${build_tag}"

? ? ? ? }

? ? }

? ? stage('Deploy to dev') {

? ? ? ? echo "5. Deploy DEV"

sh "sed -i 's/<BUILD_TAG>/${build_tag}/' k8s-dev-god.yaml"

? ? ? sh "sed -i 's/<BRANCH_NAME>/${env.BRANCH_NAME}/' k8s-dev-god.yaml"

//? ? ? ? sh "bash running-devlopment.sh"

? ? ? ? sh "kubectl apply -f k8s-dev-god.yaml? --validate=false"

}

stage('Promote to qa') {

def userInput = input(

? ? ? ? ? ? id: 'userInput',

? ? ? ? ? ? message: 'Promote to qa?',

? ? ? ? ? ? parameters: [

? ? ? ? ? ? ? ? [

? ? ? ? ? ? ? ? ? ? $class: 'ChoiceParameterDefinition',

? ? ? ? ? ? ? ? ? ? choices: "YES\nNO",

? ? ? ? ? ? ? ? ? ? name: 'Env'

? ? ? ? ? ? ? ? ]

? ? ? ? ? ? ]

? ? ? ? )

? ? ? ? echo "This is a deploy step to ${userInput}"

? ? ? ? if (userInput == "YES") {

? ? ? ? ? ? sh "sed -i 's/<BUILD_TAG>/${build_tag}/' k8s-qa-god.yaml"

sh "sed -i 's/<BRANCH_NAME>/${env.BRANCH_NAME}/' k8s-qa-god.yaml"

//? ? ? ? ? ? sh "bash running-qa.sh"

? ? ? ? ? ? sh "kubectl apply -f k8s-qa-god.yaml --validate=false"

? ? ? ? ? ? sh "sleep 6"

? ? ? ? ? ? sh "kubectl get pods -n qatest"

? ? ? ? } else {

? ? ? ? ? ? //exit

? ? ? ? }

? ? }

stage('Promote to pro') {

def userInput = input(

? ? ? ? ? ? id: 'userInput',

? ? ? ? ? ? message: 'Promote to pro?',

? ? ? ? ? ? parameters: [

? ? ? ? ? ? ? ? [

? ? ? ? ? ? ? ? ? ? $class: 'ChoiceParameterDefinition',

? ? ? ? ? ? ? ? ? ? choices: "YES\nNO",

? ? ? ? ? ? ? ? ? ? name: 'Env'

? ? ? ? ? ? ? ? ]

? ? ? ? ? ? ]

? ? ? ? )

? ? ? ? echo "This is a deploy step to ${userInput}"

? ? ? ? if (userInput == "YES") {

? ? ? ? ? ? sh "sed -i 's/<BUILD_TAG>/${build_tag}/' k8s-prod-god.yaml"

? ? ? ? ? ? sh "sed -i 's/<BRANCH_NAME>/${env.BRANCH_NAME}/' k8s-prod-god.yaml"

//? ? ? ? ? ? sh "bash running-production.sh"

? ? ? ? ? ? sh "cat k8s-prod-god.yaml"

? ? ? ? ? ? sh "kubectl apply -f k8s-prod-god.yaml --record --validate=false"

? ? ? ? }

? ? }

}

god?變成自己的?dockerhub?用戶名?k8s-prod-god.yaml

應用------>保存------>立即構建 在左側可以看到構建任務,如下所示:

點擊?Console Output,可以看到?pipeline?定義的步驟的詳細信息

點擊?Input request,部署應用到預生產環境

點擊?Input request,部署應用到生產環境

看到?Finished:SUCCESS,,說明?pipeline?構建任務完成

報錯?1

解決方法:請修改 Pipeline script 處標簽更改為自己的 dockerhub 的 username。

6、驗證開發、預生產、生產環境部署的應用是否正常運行

]# kubectl get pods -n devlopment

NAME READY STATUS RESTARTS AGE

jenkins-demo-784885d9c9-b4jkg 1/1 Running 0

]#kubectl get pods -n qatest

NAME READY STATUS RESTARTS AGE jenkins-demo-784885d9c9-59tsm 1/1 Running 0 5m19s

]#kubectl get pods -n production

NAME READY STATUS jenkins-demo-784885d9c9-42hz4 1/1 running

Jenkins?管理插件?BlueOcean?配置和使用

# BlueOcean?是什么?

為了適應 Jenkins Pipeline?和?Freestyle jobs?任務,Jenkins?推出了?BlueOcean UI,其目的就 是讓程序員執行任務時,降低工作流程的復雜度和提升工作流程的清晰度,它具有如下特征:?1、清晰的可視化:對?CI/CD pipelines,?可以快速直觀的觀察項目?pipeline?狀態。

2、pipeline?可編輯:引導用戶通過直觀的、可視化的過程來創建?Pipeline,從而使?Pipeline?的創 建變得平易近人。

3、pipeline?精確度:通過?UI?直接介入?pipeline?的中間問題。

#安裝?BlueOcean?插件 主頁—>系統管理→插件管理→可選插件—>過濾?BlueOcean→直接安裝

安裝完成后,重啟?jenkins

http://192.168.172.163:30002/restart

重啟進入?jenkins?之后,在主頁左側可以看到打開?Blue Ocean

Jenkins?實現?k8s?應用按照指定版本回滾

回到首頁:

新建一個任務------>輸入一個任務名稱處輸入?jenkins-variable-test-deploy-rollout------>流水 線------>確定------>在?Pipeline script?處輸入如下內容

node('testhan') {

? stage('git clone') {

? ? git url: "https://github.com/luckylucky421/jenkins-rollout"

? ? sh "ls -al"

? ? sh "pwd"

}

stage('select env') {

? def envInput = input(

? ? id: 'envInput',

? ? message: 'Choose a deploy environment',

? ? parameters: [

? ? ? [

? ? ? ? $class: 'ChoiceParameterDefinition',

? ? ? ? choices: "devlopment\nqatest\nproduction",

? ? ? ? name: 'Env'

? ? ? ]

? ? ]

)

echo "This is a deploy step to ${envInput}"

sh "sed -i 's/<namespace>/${envInput}/' getVersion.sh"

sh "sed -i 's/<namespace>/${envInput}/' rollout.sh"

sh "bash getVersion.sh"

// env.WORKSPACE = pwd()

// def version = readFile "${env.WORKSPACE}/version.csv"

// println version

}

stage('select version') {

? env.WORKSPACE = pwd()

def version = readFile "${env.WORKSPACE}/version.csv"

println version

? def userInput = input(id: 'userInput',

? ? message: '選擇回滾版本',

? ? parameters: [

? ? ? [

? ? ? ? $class: 'ChoiceParameterDefinition',

? ? ? ? choices: "$version\n",

? ? ? ? name: 'Version'

? ? ? ]

? ? ? ? ]

)

? ? sh "sed -i 's/<version>/${userInput}/' rollout.sh"

}

stage('rollout deploy') {

? ? sh "bash rollout.sh"

}

}

點擊應用->保存-立即構建

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,533評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,055評論 3 414
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,365評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,561評論 1 307
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,346評論 6 404
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 54,889評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 42,978評論 3 439
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,118評論 0 286
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,637評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,558評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,739評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,246評論 5 355
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 43,980評論 3 346
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,362評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,619評論 1 280
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,347評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,702評論 2 370

推薦閱讀更多精彩內容