原創(chuàng)文章,歡迎轉(zhuǎn)載俄认。轉(zhuǎn)載請(qǐng)注明:轉(zhuǎn)載自IT人故事會(huì)个少,謝謝洪乍!
原文鏈接地址:『中級(jí)篇』容器編排Docker Swarm介紹(42)
到今天這次總結(jié),如果跟著我一起學(xué)一起練的老鐵夜焦,完全入門docker了壳澳。在日常的開發(fā)和測(cè)試,絕對(duì)是沒(méi)有問(wèn)題的茫经。不管是我們自己和docker公司巷波,他們的初心都是想用在生產(chǎn)環(huán)境下,但是生產(chǎn)環(huán)境和測(cè)試環(huán)境完全是兩種環(huán)境條件卸伞。
之前的學(xué)習(xí)實(shí)踐環(huán)境
在用學(xué)習(xí)容器編排之前抹镊,所有操作本地進(jìn)行的,docker cli 連接是一臺(tái)的docker host荤傲,不管是docker run 還是docker container 都是在一臺(tái)機(jī)器上垮耳,但是實(shí)際的生產(chǎn)環(huán)境下,一個(gè)應(yīng)用很復(fù)雜他部署在一臺(tái)機(jī)器上滿足不了我們的需求遂黍,都是通過(guò)集群的方式來(lái)解決問(wèn)題的终佛。
到處都使用容器帶來(lái)的困擾
- 怎么去管理這么多容器?
- 怎么能方便的橫向擴(kuò)展雾家?
- 如果容器down了铃彰,怎么能自動(dòng)恢復(fù)?
- 如何去更新融起而不影響業(yè)務(wù)芯咧?
- 怎么去調(diào)度容器的創(chuàng)建牙捉?
- 保護(hù)隱私數(shù)據(jù)?
Swarm的架構(gòu)
- swarm集群的架構(gòu)
- 節(jié)點(diǎn)下面有角色:Worker Manager
- Manager 是整個(gè)warm集群的大腦敬飒,為了避免單點(diǎn)的故障邪铲,我們的大腦至少有2個(gè),狀態(tài)的同步通過(guò)raft協(xié)議進(jìn)行同步驶拱。raft協(xié)議可以確保多個(gè)Manager之前是同步的霜浴。
分布式系統(tǒng)之于單機(jī)系統(tǒng),優(yōu)勢(shì)之一就是有更好的容錯(cuò)性蓝纲。
- 比如阴孟,一臺(tái)機(jī)器上的磁盤損壞,數(shù)據(jù)丟失税迷,可以從另一臺(tái)機(jī)器上的磁盤>恢復(fù)(分布式系統(tǒng)會(huì)對(duì)數(shù)據(jù)做備份)
- 比如永丝,集群中某些機(jī)器宕機(jī),整個(gè)集群還可以對(duì)外提供服務(wù)
這是如何做到的箭养?比較容易的一個(gè)想法就是備份(backup)慕嚷。一個(gè)系統(tǒng)的工作模是:接受客戶端的command,系統(tǒng)進(jìn)行處理,將處理的結(jié)果返回給客戶端喝检。由此可見嗅辣,系統(tǒng)里的數(shù)據(jù)可能會(huì)因?yàn)閏ommand而變化。
實(shí)現(xiàn)備份的做法之一就是復(fù)制狀態(tài)機(jī)(Repilcated State Machine挠说,RSM)澡谭,它有一個(gè)很重要的性質(zhì)——確定性(deterministic):- 如果兩個(gè)相同的、確定性的狀態(tài)從同一狀態(tài)開始损俭,并且以相同的順序獲得相同的輸入蛙奖,那么這兩個(gè)狀態(tài)機(jī)將會(huì)生成相同的輸出,并且結(jié)束在相同的狀態(tài)
也就是說(shuō)杆兵,如果我們能按順序?qū)ommand作用于狀態(tài)機(jī)雁仲,它就可以產(chǎn)生相同的狀態(tài)和相同的輸出
那么一個(gè)狀態(tài)機(jī)如何實(shí)現(xiàn)呢?如下圖所示(來(lái)自raft協(xié)議):
image
上圖中琐脏,每個(gè)RSM都有一個(gè)replicated log攒砖,存儲(chǔ)的是來(lái)自客戶端的commands。每個(gè)RSM中replicate log中commads的順序都是相同的骆膝,狀態(tài)機(jī)按順序處理replicate log中的command,并將處理的結(jié)果返回給客戶端祭衩。由于狀態(tài)機(jī)具有確定性灶体,因此每個(gè)狀態(tài)機(jī)的輸出和狀態(tài)都是相同的阅签。
上圖中有一個(gè)模塊——Consensus Module剛剛沒(méi)有提及。這個(gè)模塊用于保證每個(gè)server上Log的一致性蝎抽!
- 如果不做任何保障政钟,直接將commad暴力寫入,一旦服務(wù)器宕機(jī)或者出現(xiàn)什么其他故障樟结,就會(huì)導(dǎo)致這個(gè)Log丟失养交,并且無(wú)法恢復(fù)。而出現(xiàn)故障的可能性是很高的瓢宦,這就導(dǎo)致系統(tǒng)不可用
- raft就是Consensus Module的一個(gè)實(shí)現(xiàn)
因此碎连,raft是一致性協(xié)議,是用來(lái)保障servers上副本一致性的一種算法驮履。
- worker是通過(guò)gossip的網(wǎng)絡(luò)結(jié)構(gòu)進(jìn)行同步
-
Service 和Replicas鱼辙,這里的Service在docker compose中的Service是一樣的。
命令合集
個(gè)人主頁(yè):IT人故事會(huì)
PS:之后通過(guò)很多很多的實(shí)踐操作一起來(lái)學(xué)習(xí)Swarm玫镐。
往期精彩
- docker導(dǎo)學(xué)(一)
- 容器的技術(shù)概述(二)
- docker的魅力初體驗(yàn)-5分鐘安裝wordpress不走彎路(三)
- docker官網(wǎng)介紹(四)
- 如何在mac上安裝docker(五)
- 如何在window上安裝docker(六)
- 如何在mac上通過(guò)vagrant安裝虛擬機(jī)(七)
- 如何在window上通過(guò)vagrant安裝虛擬機(jī)(八)
- docker-Machine的本地使用(九)
- docker-Machine的本地使用(十)
- 在linux/mac下通過(guò)Docker-Machine在阿里云上的使用(11)
- docker架構(gòu)和底層技術(shù)(12)
- docker Image概述(13)
- 手動(dòng)建立一個(gè)base Image(14)
- 什么是Container(15)
- 構(gòu)建自己的Docker鏡像(16)
- Dockerfile詳解(17)
- 鏡像的發(fā)布(18)
- Dockerfile實(shí)戰(zhàn)(19)
- 容器的操作(20)
- Dockerfile實(shí)戰(zhàn)CMD和ENTRTYPOINT的配合(21)
- 容器的資源限制(22)
- docker網(wǎng)絡(luò)(23)
- docker學(xué)習(xí)必會(huì)網(wǎng)絡(luò)基礎(chǔ)(24)
- Linux網(wǎng)絡(luò)命名空間(25)
- Docker Bridge詳解(26)
- 容器之間的Link(27)
- 容器的端口映射(28)
- 容器網(wǎng)絡(luò)之host和none(29)
- 多容器復(fù)雜應(yīng)用的部署(30)
- overlay網(wǎng)絡(luò)和etcd實(shí)現(xiàn)多機(jī)的容器通信(31)
- docker的數(shù)據(jù)持久化存儲(chǔ)和數(shù)據(jù)共享(32)
- windows下vagrant 通過(guò)SecureCRT連接centos7(33)
- 數(shù)據(jù)持久化之Data Volume(34)
- 數(shù)據(jù)持久化之bind Mounting(35)
- docker 使用bind Mounting實(shí)戰(zhàn)(36)
- docker容器安裝wordpress(37)
- docker Compose到底是什么(38)
- Docker Compose的安裝和基本使用(39)
- Docker 水平擴(kuò)展和負(fù)載均衡(40)
- Docker compose 部署一個(gè)復(fù)雜的應(yīng)用(41)