python 微服務(wù)在Docker k8s下如何部署?
微服務(wù)在Docker k8s下如何部署?最近,這些技術(shù)已經(jīng)在項(xiàng)目中使用。讓我介紹一些有價(jià)值的想法。首先,結(jié)論如下:1。K8s是一款非常好的技術(shù),非常穩(wěn)定。如果發(fā)現(xiàn)正在運(yùn)行的pod數(shù)量不等于用戶設(shè)置的期
微服務(wù)在Docker k8s下如何部署?
最近,這些技術(shù)已經(jīng)在項(xiàng)目中使用。讓我介紹一些有價(jià)值的想法。
首先,結(jié)論如下:
1。K8s是一款非常好的技術(shù),非常穩(wěn)定。如果發(fā)現(xiàn)正在運(yùn)行的pod數(shù)量不等于用戶設(shè)置的期望值,k8s將自動(dòng)創(chuàng)建或刪除pod,直到它們相等為止。這不僅確保了服務(wù)的不間斷運(yùn)行,而且還動(dòng)態(tài)地?cái)U(kuò)展了服務(wù)規(guī)范。用戶只需要調(diào)整pod的復(fù)制次數(shù),剩下的留給k8s,這很容易讓人擔(dān)心。
2. 使用Jenkins集成命令行操作,雖然我個(gè)人比較喜歡使用命令行,但我不得不承認(rèn),使用Jenkins集成命令行操作將大大提高工作效率。
實(shí)現(xiàn)步驟如下:(本文以Azure平臺(tái)為例)
1。寫(xiě)dockerfile
2。在Jenkins中創(chuàng)建任務(wù)并執(zhí)行包含以下命令的腳本
2.1 git將源代碼拉到本地
2.2 docker build命令生成映像文件
2.3 docker定義映像文件版本號(hào)并上載到Azure平臺(tái)
2.4 kubectl命令創(chuàng)建k8s部署和服務(wù)。
每個(gè)版本2.5update,可以調(diào)用update image來(lái)編譯新的鏡像版本并提供給k8s
注意,在創(chuàng)建k8s的部署和服務(wù)時(shí),需要用yaml格式編寫(xiě)配置文件。部署配置包括名稱、映像文件地址、最大和最小CPU分配值、最大和最小內(nèi)存分配值等。服務(wù)配置文件包括名稱、引用的部署名稱以及是否使用負(fù)載平衡器。
有關(guān)更多詳細(xì)信息,請(qǐng)參閱我的wikihttps://github.com/FamingHou/MyWiki
為什么說(shuō)docker是一種革命性的技術(shù)?
一個(gè)非常好的問(wèn)題。我是一個(gè)web應(yīng)用程序架構(gòu)師,多年來(lái)一直致力于回答這個(gè)問(wèn)題。歡迎跟我來(lái)了解更多。
和工具。
Docker基于Linux內(nèi)核。它通過(guò)操作系統(tǒng)和虛擬容器調(diào)用CGroup、namespace等系統(tǒng)接口,完成資源分配和相互隔離。它依賴于系統(tǒng)資源來(lái)運(yùn)行。使用的技術(shù)都是現(xiàn)有的。
有VMware虛擬機(jī)和ghost,它們?nèi)栽谑褂弥小K鼈儾糠纸鉀Q了服務(wù)器安裝和配置的瑣碎工作,但沒(méi)有解決運(yùn)行環(huán)境的問(wèn)題。例如,環(huán)境不一致的常見(jiàn)問(wèn)題:開(kāi)發(fā)環(huán)境可以運(yùn)行,而測(cè)試生產(chǎn)環(huán)境有bug?在構(gòu)建新的服務(wù)器和新的環(huán)境時(shí),會(huì)遇到無(wú)數(shù)的問(wèn)題。
整個(gè)環(huán)境是打包的,也就是說(shuō),所有的安裝和配置都是編碼和自動(dòng)化的。結(jié)合資源編排和云服務(wù),集群Web服務(wù)系統(tǒng)可以在幾秒鐘內(nèi)啟動(dòng),這是沒(méi)有容器技術(shù)無(wú)法完成的。Docker是最常用的集裝箱技術(shù),其實(shí)是集裝箱技術(shù)的標(biāo)準(zhǔn)。
建議觀看docker第二個(gè)web服務(wù)視頻:https://www.toutiao.com/i6801418770997838343/