Go微服務(wù)架構(gòu)實(shí)戰(zhàn) 中篇:3. 擴(kuò)縮容、自愈和故障轉(zhuǎn)移鹿驼、滾動更新以及回退能力

Go微服務(wù)架構(gòu)實(shí)戰(zhàn)-【公粽號:堆棧future】

Go微服務(wù)架構(gòu)實(shí)戰(zhàn)目錄

1. 微服務(wù)架構(gòu)上篇

1. grpc技術(shù)介紹

2. grpc+protobuf+網(wǎng)關(guān)實(shí)戰(zhàn)

3. etcd技術(shù)介紹

4. 基于etcd的服務(wù)發(fā)現(xiàn)與注冊

5. 基于etcd的分布式鎖實(shí)戰(zhàn)

2. 微服務(wù)架構(gòu)中篇

1. k8s架構(gòu)介紹

2. 基于k8s的容器化部署

基于k8s的Deployment工作負(fù)載

主要是利用Deployment資源對象實(shí)現(xiàn)的面哼,包括一下功能:

  1. 多副本集
  2. 擴(kuò)縮容
  3. 自愈和故障轉(zhuǎn)移
  4. 滾動更新
  5. 回退能力

接下來詳細(xì)了解下操作過程

1. 多副本集

deploy.yaml中只需修改一下replicas政敢,讓它的值變成我們想要的副本數(shù)量。

<pre data-tool="mdnice編輯器" style="box-sizing: border-box !important; margin: 10px 0px; padding: 0px; outline: 0px; font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: 14px; overflow: auto; display: block; color: rgb(33, 37, 41); max-width: 100%; overflow-wrap: break-word !important; font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: 400; letter-spacing: 0.8px; orphans: 2; text-align: left; text-indent: 0px; text-transform: none; widows: 2; word-spacing: 0.8px; -webkit-text-stroke-width: 0px; background-color: rgb(255, 255, 255); text-decoration-thickness: initial; text-decoration-style: initial; text-decoration-color: initial; border-radius: 5px; box-shadow: rgba(0, 0, 0, 0.55) 0px 2px 10px;">apiVersion: apps/v1 kind: Deployment metadata: name: k8sdemo-deploy labels: app: k8sdemo spec: replicas: 3 //修改這里 selector: matchLabels: app: k8sdemo template: metadata: labels: app: k8sdemo spec: containers: - name: k8sdemo image: k8s-grpc-demo:latest imagePullPolicy: Never ports: - containerPort: 50007 </pre>

然后kubectl apply -f deploy.yaml應(yīng)用一下就可以了,看下創(chuàng)建結(jié)果:

image.gif

從結(jié)果看出三個(gè)pod成功起來了。

2. 擴(kuò)縮容

比較簡單,一行命令搞定:

kubectl scale --replicas=1 deployment/k8sdemo-deploy回車之后打印如下:

image.gif

然后看下pod數(shù)量kubectl get pod發(fā)現(xiàn)只有一個(gè)pod了,這里就不展示了职祷,非常簡單痰催。

3. 自愈和故障轉(zhuǎn)移

因?yàn)槲抑挥幸慌_機(jī)器胎食,沒辦法驗(yàn)證扰才,所以只列出步驟,下去大家自己可以嘗試厕怜。

  • 停某一臺機(jī)器
  • 刪除某個(gè)pod

大家可以去試試衩匣,看看是否停掉機(jī)器之后,pod會在別的機(jī)器上再起來粥航,保持Deployment的副本集數(shù)量不變琅捏。或者在某臺機(jī)器上刪除某個(gè)pod之后递雀,看看這個(gè)pod是否重新建立(歸功于Deployment的能力)柄延。

tips:當(dāng)你要?jiǎng)h除pod的時(shí)候發(fā)現(xiàn)一直刪除不掉,pod會自動起來缀程,不要著急莫慌搜吧,你應(yīng)該先刪除Deployment,這樣pod就會自動刪除的杨凑。

4. 滾動更新

首先你基于你的代碼做了部分更新滤奈,比如增加了日志等功能,然后在本地構(gòu)建鏡像撩满,比如k8s-grpc-demo:v2蜒程,然后你用一行命令就可以搞定滾動更新:

<pre data-tool="mdnice編輯器" style="box-sizing: border-box !important; margin: 10px 0px; padding: 0px; outline: 0px; font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: 14px; overflow: auto; display: block; color: rgb(33, 37, 41); max-width: 100%; overflow-wrap: break-word !important; font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: 400; letter-spacing: 0.8px; orphans: 2; text-align: left; text-indent: 0px; text-transform: none; widows: 2; word-spacing: 0.8px; -webkit-text-stroke-width: 0px; background-color: rgb(255, 255, 255); text-decoration-thickness: initial; text-decoration-style: initial; text-decoration-color: initial; border-radius: 5px; box-shadow: rgba(0, 0, 0, 0.55) 0px 2px 10px;">kubectl set image deployment/k8sdemo-deploy k8s-grpc-demo=k8s-grpc-demo:v2 --record </pre>

查看下更新狀態(tài)

<pre data-tool="mdnice編輯器" style="box-sizing: border-box !important; margin: 10px 0px; padding: 0px; outline: 0px; font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: 14px; overflow: auto; display: block; color: rgb(33, 37, 41); max-width: 100%; overflow-wrap: break-word !important; font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: 400; letter-spacing: 0.8px; orphans: 2; text-align: left; text-indent: 0px; text-transform: none; widows: 2; word-spacing: 0.8px; -webkit-text-stroke-width: 0px; background-color: rgb(255, 255, 255); text-decoration-thickness: initial; text-decoration-style: initial; text-decoration-color: initial; border-radius: 5px; box-shadow: rgba(0, 0, 0, 0.55) 0px 2px 10px;">kubectl rollout status deployment/k8sdemo-deploy </pre>

圖片

5. 回退能力

  1. 查看歷史版本記錄

<pre data-tool="mdnice編輯器" style="box-sizing: border-box !important; margin: 10px 0px; padding: 0px; outline: 0px; font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: 14px; overflow: auto; display: block; color: rgb(33, 37, 41); max-width: 100%; overflow-wrap: break-word !important; font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: 400; letter-spacing: 0.8px; orphans: 2; text-align: left; text-indent: 0px; text-transform: none; widows: 2; word-spacing: 0.8px; -webkit-text-stroke-width: 0px; background-color: rgb(255, 255, 255); text-decoration-thickness: initial; text-decoration-style: initial; text-decoration-color: initial; border-radius: 5px; box-shadow: rgba(0, 0, 0, 0.55) 0px 2px 10px;">kubectl rollout history deployment/k8sdemo-deploy </pre>

圖片
  1. 查看某個(gè)歷史詳情

<pre data-tool="mdnice編輯器" style="box-sizing: border-box !important; margin: 10px 0px; padding: 0px; outline: 0px; font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: 14px; overflow: auto; display: block; color: rgb(33, 37, 41); max-width: 100%; overflow-wrap: break-word !important; font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: 400; letter-spacing: 0.8px; orphans: 2; text-align: left; text-indent: 0px; text-transform: none; widows: 2; word-spacing: 0.8px; -webkit-text-stroke-width: 0px; background-color: rgb(255, 255, 255); text-decoration-thickness: initial; text-decoration-style: initial; text-decoration-color: initial; border-radius: 5px; box-shadow: rgba(0, 0, 0, 0.55) 0px 2px 10px;">kubectl rollout history deployment/k8sdemo-deploy --revision=2 </pre>

圖片
  1. 回滾(回到上次)

<pre data-tool="mdnice編輯器" style="box-sizing: border-box !important; margin: 10px 0px; padding: 0px; outline: 0px; font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: 14px; overflow: auto; display: block; color: rgb(33, 37, 41); max-width: 100%; overflow-wrap: break-word !important; font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: 400; letter-spacing: 0.8px; orphans: 2; text-align: left; text-indent: 0px; text-transform: none; widows: 2; word-spacing: 0.8px; -webkit-text-stroke-width: 0px; background-color: rgb(255, 255, 255); text-decoration-thickness: initial; text-decoration-style: initial; text-decoration-color: initial; border-radius: 5px; box-shadow: rgba(0, 0, 0, 0.55) 0px 2px 10px;">kubectl rollout undo deployment/k8sdemo-deploy </pre>

  1. 回滾(回到指定版本)

<pre data-tool="mdnice編輯器" style="box-sizing: border-box !important; margin: 10px 0px; padding: 0px; outline: 0px; font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: 14px; overflow: auto; display: block; color: rgb(33, 37, 41); max-width: 100%; overflow-wrap: break-word !important; font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: 400; letter-spacing: 0.8px; orphans: 2; text-align: left; text-indent: 0px; text-transform: none; widows: 2; word-spacing: 0.8px; -webkit-text-stroke-width: 0px; background-color: rgb(255, 255, 255); text-decoration-thickness: initial; text-decoration-style: initial; text-decoration-color: initial; border-radius: 5px; box-shadow: rgba(0, 0, 0, 0.55) 0px 2px 10px;">kubectl rollout undo deploymen/k8sdemo-deploy --to-revision=2 </pre>

6. 小結(jié)

其實(shí)k8s使用不是很復(fù)雜,你可以學(xué)完k8s之后搭建自己的服務(wù)伺帘,但是如果想深入定制k8s昭躺,需要有一定golang知識和容器化知識,所以想要進(jìn)階的可以在深入學(xué)習(xí)下源碼理解下原理曼追。

下篇文章繼續(xù)給大家講解下k8s的service的服務(wù)注冊和發(fā)現(xiàn)能力和ingress的入口網(wǎng)關(guān)能力窍仰,以及它們的網(wǎng)絡(luò)架構(gòu)知識。喜歡這篇文章的童鞋可以關(guān)注礼殊,轉(zhuǎn)發(fā)和分享哈驹吮。

github地址:https://github.com/guojiangli/k8s-grpc-demo

【公粽號:堆棧future】

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市晶伦,隨后出現(xiàn)的幾起案子碟狞,更是在濱河造成了極大的恐慌,老刑警劉巖婚陪,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件族沃,死亡現(xiàn)場離奇詭異,居然都是意外死亡泌参,警方通過查閱死者的電腦和手機(jī)脆淹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來沽一,“玉大人盖溺,你說我怎么就攤上這事∠巢” “怎么了烘嘱?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長蝗蛙。 經(jīng)常有香客問我蝇庭,道長,這世上最難降的妖魔是什么捡硅? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任哮内,我火速辦了婚禮,結(jié)果婚禮上壮韭,老公的妹妹穿的比我還像新娘北发。我一直安慰自己,他們只是感情好泰涂,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布鲫竞。 她就那樣靜靜地躺著,像睡著了一般逼蒙。 火紅的嫁衣襯著肌膚如雪从绘。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天是牢,我揣著相機(jī)與錄音僵井,去河邊找鬼。 笑死驳棱,一個(gè)胖子當(dāng)著我的面吹牛批什,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播社搅,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼驻债,長吁一口氣:“原來是場噩夢啊……” “哼乳规!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起合呐,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤暮的,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后淌实,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體冻辩,經(jīng)...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年拆祈,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了恨闪。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,785評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡放坏,死狀恐怖咙咽,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情轻姿,我是刑警寧澤犁珠,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站互亮,受9級特大地震影響犁享,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜豹休,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一炊昆、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧威根,春花似錦凤巨、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至留美,卻和暖如春彰檬,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背谎砾。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工逢倍, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人景图。 一個(gè)月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓较雕,卻偏偏與公主長得像,于是被迫代替她去往敵國和親挚币。 傳聞我的和親對象是個(gè)殘疾皇子亮蒋,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評論 2 354

推薦閱讀更多精彩內(nèi)容