docker swarm 集群故障與異常詳解
本文介紹了docker swarm 集群故障與異常詳解,分享給大家,具體如下:

在上次遭遇 docker swarm 集群故障后,我們將 docker 由 17.10.0-ce 升級(jí)為最新穩(wěn)定版 docker 17.12.0-ce 。
前天晚上22:00之后集群中的2個(gè)節(jié)點(diǎn)突然出現(xiàn)CPU波動(dòng),在CPU波動(dòng)之后,在凌晨夜深人靜、訪問(wèn)量極低的時(shí)候,整個(gè)集群出現(xiàn)了故障,訪問(wèn)集群上的所有站點(diǎn)都出現(xiàn)了502,過(guò)了一段時(shí)間后自動(dòng)恢復(fù)正常。
ECS實(shí)例:swarm1-node5,CPU百分比于00:52發(fā)生告警,值為96.14%,持續(xù)時(shí)間0分鐘
。。。
昨天早上發(fā)現(xiàn)訪問(wèn)部分節(jié)點(diǎn)中的容器應(yīng)用響應(yīng)有些慢,于是我們通過(guò)阿里云控制臺(tái)強(qiáng)制重啟這些節(jié)點(diǎn)后恢復(fù)正常。
今天上午我們?cè)诩荷细乱粋€(gè)應(yīng)用時(shí)(部署新的鏡像),出現(xiàn)了奇怪的問(wèn)題。應(yīng)用是在 swarm1-node1 這個(gè) manager 節(jié)點(diǎn)上部署的,部署后容器運(yùn)行在其他節(jié)點(diǎn)上,但奇怪的是只有在 swarm1-node1 這個(gè)節(jié)點(diǎn)上可以正常訪問(wèn)容器中的站點(diǎn),在其他節(jié)點(diǎn)上訪問(wèn)都是 503 ,用 docker stack rm 命令刪除應(yīng)用并重新部署問(wèn)題依舊。
當(dāng)時(shí) docker-flow-proxy(路由應(yīng)用) 的 2 個(gè)容器都是部署在 swarm1-node1 節(jié)點(diǎn)上的,從問(wèn)題現(xiàn)象看,在 swarm1-node1 節(jié)點(diǎn)上 docker-flow-proxy 容器與外界的通信正常,docker-flow-proxy 容器與其他節(jié)點(diǎn)上的容器的 overlay 網(wǎng)絡(luò)(網(wǎng)絡(luò)A)通信正常;在其他節(jié)點(diǎn)上,外界的請(qǐng)求通過(guò) overlay 網(wǎng)絡(luò)(網(wǎng)絡(luò)B)被正常轉(zhuǎn)發(fā)到 docker-flow-proxy 容器,卻不能被正常路由到其他節(jié)點(diǎn)上對(duì)應(yīng)的容器(也是通過(guò) overlay 網(wǎng)絡(luò)A)。對(duì)這個(gè)奇怪現(xiàn)象實(shí)在想不通,但是問(wèn)題擺在那,想不通也要解決。想不通背后的原因,那我們換個(gè)角度,其他節(jié)點(diǎn)都異常,就 swarm1-node1 正常,根據(jù)少數(shù)服從多數(shù)的粗暴原則,那就認(rèn)為swarm1-node1 不正常吧。于是通過(guò)下面的命令將swarm1-node1 節(jié)點(diǎn)下線:
docker node update --availability drain swarm1-node1
swarm1-node1 下線后,其他節(jié)點(diǎn)都恢復(fù)了正常,果然是 swarm1-node1 不正常。
swarm1-node1 下線的背后是 docker-flow-proxy 容器換到其他節(jié)點(diǎn)上運(yùn)行。

問(wèn)題就這樣被猜測(cè)解決了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
supervisor下的Dockerfile的多服務(wù)鏡像封裝操作
這篇文章主要介紹了supervisor下的Dockerfile的多服務(wù)鏡像封裝操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11
Docker網(wǎng)絡(luò)之單host網(wǎng)絡(luò)及使用案例
本文重點(diǎn)給大家講解Docker單主機(jī)網(wǎng)絡(luò)的相關(guān)知識(shí)及使用案例,重點(diǎn)是使用案例,感興趣的朋友一起看看吧2017-08-08
Docker+selenium實(shí)現(xiàn)自動(dòng)化健康報(bào)備的方法
這篇文章主要介紹了Docker+selenium實(shí)現(xiàn)自動(dòng)化健康報(bào)備的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
5分鐘教你實(shí)現(xiàn)用docker搭建Redis集群模式和哨兵模式
本文主要介紹了5分鐘實(shí)現(xiàn)用docker搭建Redis集群模式和哨兵模式,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
IDEA連接遠(yuǎn)程服務(wù)器Docker部署Spring Boot項(xiàng)目的詳細(xì)教程
這篇文章主要介紹了IDEA連接遠(yuǎn)程服務(wù)器Docker部署Spring Boot項(xiàng)目,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06
Docker私有倉(cāng)庫(kù)管理和刪除本地倉(cāng)庫(kù)中的鏡像
這篇文章主要介紹了Docker私有倉(cāng)庫(kù)管理和刪除本地倉(cāng)庫(kù)中的鏡像,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-01-01

