欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Docker使用Swarm組建集群的方法

 更新時間:2017年11月16日 14:19:26   作者:kongxx  
Docker 使用 Swarm 可以很方便的在多個主機(jī)上創(chuàng)建容器集群,并且容器之間可以跨主機(jī)網(wǎng)絡(luò)通信。這篇文章主要介紹了Docker使用Swarm組建集群,需要的朋友可以參考下

Swarm 在 Docker 1.12 版本之前屬于一個獨立的項目,在 Docker 1.12 版本發(fā)布之后,該項目合并到了 Docker 中,成為 Docker 的一個子命令。目前,Swarm 是 Docker 社區(qū)提供的唯一一個原生支持 Docker 集群管理的工具。它可以把多個 Docker 主機(jī)組成的系統(tǒng)轉(zhuǎn)換為單一的虛擬 Docker 主機(jī),使得容器可以組成跨主機(jī)的子網(wǎng)網(wǎng)絡(luò)。

Docker 使用 Swarm 可以很方便的在多個主機(jī)上創(chuàng)建容器集群,并且容器之間可以跨主機(jī)網(wǎng)絡(luò)通信。

Swarm 的集群分為 Manager 節(jié)點和 Worker 節(jié)點。

Swarm 中使用 Service 來創(chuàng)建/管理使用相同鏡像的多個容器,多個容器同時對外提供服務(wù),多個容器之間負(fù)載均衡。每個 Service 有一個浮動IP(VIP),各個容器還有自己的物理IP。創(chuàng)建基于 Swarm 的 Overlay 網(wǎng)絡(luò),將 Service 掛載到此網(wǎng)絡(luò)上。然后 Service 中的各個容器便可以通過 Service 名稱和 IP 地址實現(xiàn)網(wǎng)絡(luò)互通。

下面使用了三個機(jī)器來組建一個Swarm集群

bd0    192.168.0.109
bd1    192.168.0.192
bd2    192.168.0.193

Docker 開啟遠(yuǎn)程管理

默認(rèn)情況下,Docker守護(hù)進(jìn)程會生成一個 /var/run/docker.sock 文件來進(jìn)行本地進(jìn)程通信,而不會監(jiān)聽任何端口,所以默認(rèn)情況下 Docker 只能在本地使用命令行操作。 如果要在其它機(jī)器上遠(yuǎn)程操作 Docker 主機(jī),就需要讓 Docker 監(jiān)聽一個端口,這樣才能實現(xiàn)遠(yuǎn)程通信。

在我的 CentOS 7X 上,首先修改 Docker 配置文件 /etc/sysconfig/docker 中的 OPTIONS 參數(shù),添加

-H unix:///var/run/docker.sock -H 0.0.0.0:5555

修改后參數(shù)類似

OPTIONS='--selinux-enabled --log-driver=journald --signature-verification=false -H unix:///var/run/docker.sock -H 0.0.0.0:5555'

然后重新啟動 Docker 服務(wù)

$ sudo systemctl restart docker.service

測試一下

sudo docker -H <HOST>:5555 images

創(chuàng)建 Swarm 集群

獲取 Swarm 鏡像

分別在三個節(jié)點上下載swarm鏡像

$ sudo docker pull swarm

初始化Swarm集群

首先在 bd0 節(jié)點上初始化 Swarm 集群

$ sudo docker swarm init
Error response from daemon: could not choose an IP address to advertise since this system has multiple addresses on different interfaces (192.168.0.109 on eth0 and 192.168.122.1 on virbr0) - specify one with --advertise-addr

第一次創(chuàng)建失敗了,原因是我的機(jī)器有兩塊網(wǎng)卡,Swarm不知道要用那塊網(wǎng)卡組建集群,所以需要使用 --advertise-addr 來指定使用那塊網(wǎng)卡。

$ sudo docker swarm init --advertise-addr 192.168.0.109
Swarm initialized: current node (1egy2ark49q6xokudps5wykhn) is now a manager.
To add a worker to this swarm, run the following command:
  docker swarm join \
  --token SWMTKN-1-0x11m2uk7ps9bh7nflkxwirgv0syvacl18rut3hilz4i9lgis3-d9m22hixt0b57hjj81im8bqdl \
  192.168.0.109:2377

To add a manager to this swarm, run 'docker swarm join-token manager' and follow the instructions.

然后分別在 bd1 和 bd2 節(jié)點上運行下面命令將機(jī)器加入集群

$ sudo docker swarm join \
 --token SWMTKN-1-0x11m2uk7ps9bh7nflkxwirgv0syvacl18rut3hilz4i9lgis3-d9m22hixt0b57hjj81im8bqdl \
 192.168.0.109:2377

This node joined a swarm as a worker.

下面查看一下集群節(jié)點信息

$ sudo docker node ls
ID              HOSTNAME STATUS AVAILABILITY MANAGER STATUS
11ochjq4o1s2m6w4u8jxb37w6  bd1    Ready  Active
1egy2ark49q6xokudps5wykhn * bd0    Ready  Active    Leader
b4e2ywnhhd6fhgfxtr1qh4gew  bd2    Ready  Active

創(chuàng)建集群跨主機(jī)網(wǎng)絡(luò)

首先查看一下集群網(wǎng)絡(luò)

$ sudo docker network ls
NETWORK ID     NAME        DRIVER       SCOPE
36679de6466b    bridge       bridge       local
72e853673d8b    docker_gwbridge   bridge       local
b45cef05e017    host        host        local
1zzlk9hpwyqy    ingress       overlay       swarm

添加一個Swarm網(wǎng)絡(luò)

$ sudo docker network create --driver overlay myswarm
a04evrfrr4cvnbvrummzvg0mn

創(chuàng)建后,查看一下集群網(wǎng)絡(luò)

$ sudo docker network ls
NETWORK ID     NAME        DRIVER       SCOPE
36679de6466b    bridge       bridge       local
72e853673d8b    docker_gwbridge   bridge       local
b45cef05e017    host        host        local
1zzlk9hpwyqy    ingress       overlay       swarm
a04evrfrr4cv    myswarm       overlay       swarm

部署服務(wù)

這里使用 nginx 服務(wù)來演示一下怎樣創(chuàng)建一個服務(wù)集群。

下載nginx鏡像

$ sudo docker pull nginx

創(chuàng)建服務(wù)

$ sudo docker service create --replicas 2 --name mynginx -p 8000:80 --network=myswarm nginx
5xrm96xveqw5gq63srts1rbhw

這里創(chuàng)建了需要兩個 nginx 實例的 nginx 服務(wù)。同時,為了能被外網(wǎng)地址訪問,我們做了一下端口映射,映射到物理主機(jī)的8000端口。

查看服務(wù)

$ sudo docker service ls
ID      NAME   REPLICAS IMAGE COMMAND
5xrm96xveqw5 mynginx 2/2    nginx
$ sudo docker service ps mynginx
ID             NAME    IMAGE NODE   DESIRED STATE CURRENT STATE      ERROR
1crmc5ecsjoci8xavxzbnbks3 mynginx.1 nginx bd0   Running    Running 23 seconds ago
divhrq89xhxka8bvb8r9zqqhz mynginx.2 nginx bd2   Running    Running 20 seconds ago
$ sudo docker service inspect mynginx
...
"VirtualIPs": [
  {
    "NetworkID": "1zzlk9hpwyqyocloxy9j9vct7",
    "Addr": "10.255.0.6/16"
  },
  {
    "NetworkID": "a04evrfrr4cvnbvrummzvg0mn",
    "Addr": "10.0.0.2/24"
  }
]
...

在bd0上查看

$ sudo docker ps
CONTAINER ID    IMAGE        COMMAND         CREATED       STATUS       PORTS        NAMES
e480d427fd51    nginx:latest    "nginx -g 'daemon off"  41 seconds ago   Up 40 seconds    80/tcp       mynginx.1.1crmc5ecsjoci8xavxzbnbks3

在bd2上查看

$ sudo docker ps
CONTAINER ID    IMAGE        COMMAND         CREATED       STATUS       PORTS        NAMES
c12d4f9eb457    nginx:latest    "nginx -g 'daemon off"  56 seconds ago   Up 52 seconds    80/tcp       mynginx.2.divhrq89xhxka8bvb8r9zqqhz

服務(wù)已經(jīng)創(chuàng)建并啟動了,下面我們在瀏覽器訪問 http://bd0:8000 來驗證一下 nginx 服務(wù)的狀態(tài)。

服務(wù)的Failover

首先我們查看一下當(dāng)前服務(wù)的狀態(tài)

$ sudo docker service ps mynginx
ID             NAME    IMAGE NODE   DESIRED STATE CURRENT STATE      ERROR
1crmc5ecsjoci8xavxzbnbks3 mynginx.1 nginx bd0   Running    Running 23 seconds ago
divhrq89xhxka8bvb8r9zqqhz mynginx.2 nginx bd2   Running    Running 20 seconds ago

然后在 bd2 上將其上的服務(wù)停止

$ sudo docker kill mynginx.2.divhrq89xhxka8bvb8r9zqqhz
mynginx.2.divhrq89xhxka8bvb8r9zqqhz

再次觀察服務(wù)狀態(tài),如下:

$ sudo docker service ps mynginx
ID             NAME      IMAGE NODE   DESIRED STATE CURRENT STATE      ERROR
1crmc5ecsjoci8xavxzbnbks3 mynginx.1   nginx bd0   Running    Running 6 minutes ago
br5iyie0dr945ixnq7s77kunr mynginx.2   nginx bd1   Running    Running 4 seconds ago
divhrq89xhxka8bvb8r9zqqhz  \_ mynginx.2 nginx bd2   Shutdown    Failed 5 seconds ago   "task: non-zero exit (137)"

可以看到在 bd1 上又起了一個實例用來接替原來在 bd2 上的實例。

服務(wù)的擴(kuò)容/縮容

增加服務(wù)實例

$ sudo docker service scale mynginx=3
mynginx scaled to 3
$ sudo docker service ps mynginx
ID             NAME      IMAGE NODE   DESIRED STATE CURRENT STATE        ERROR
1crmc5ecsjoci8xavxzbnbks3 mynginx.1   nginx bd0   Running    Running 7 minutes ago
br5iyie0dr945ixnq7s77kunr mynginx.2   nginx bd1   Running    Running about a minute ago
divhrq89xhxka8bvb8r9zqqhz  \_ mynginx.2 nginx bd2   Shutdown    Failed about a minute ago  "task: non-zero exit (137)"
985tln0aprsvjthjpve0n6qmz mynginx.3   nginx bd2   Running    Preparing 3 seconds ago

減少服務(wù)實例

$ sudo docker service scale mynginx=2
mynginx scaled to 2
$ sudo docker service ps mynginx
ID             NAME      IMAGE NODE   DESIRED STATE CURRENT STATE          ERROR
1crmc5ecsjoci8xavxzbnbks3 mynginx.1   nginx bd0   Running    Running 7 minutes ago
br5iyie0dr945ixnq7s77kunr mynginx.2   nginx bd1   Shutdown    Shutdown less than a second ago
divhrq89xhxka8bvb8r9zqqhz  \_ mynginx.2 nginx bd2   Shutdown    Failed about a minute ago    "task: non-zero exit (137)"
985tln0aprsvjthjpve0n6qmz mynginx.3   nginx bd2   Running    Running 5 seconds ago

刪除服務(wù)

$ sudo docker service rm mynginx

總結(jié)

以上所述是小編給大家介紹的Docker使用Swarm組建集群的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • win7下docker安裝與報錯問題的解決方法

    win7下docker安裝與報錯問題的解決方法

    這篇文章主要為大家詳細(xì)介紹了win7下docker安裝與報錯問題的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • 詳解docker私有倉庫搭建與使用實戰(zhàn)

    詳解docker私有倉庫搭建與使用實戰(zhàn)

    這篇文章主要介紹了詳解docker私有倉庫搭建與使用實戰(zhàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-02-02
  • docker中運行PostgreSQL容器的簡單步驟

    docker中運行PostgreSQL容器的簡單步驟

    這篇文章主要給大家介紹了關(guān)于docker中運行PostgreSQL容器的簡單步驟,隨著docker的廣泛應(yīng)用,為了提供便利的管理,PostgreSQL數(shù)據(jù)庫也支持docker的安裝方式,需要的朋友可以參考下
    2023-08-08
  • Docker匿名掛載和具名掛載的具體使用

    Docker匿名掛載和具名掛載的具體使用

    Docker的掛載是將容器內(nèi)的目錄和宿主機(jī)的目錄進(jìn)行綁定,本文主要介紹了Docker匿名掛載和具名掛載的具體使用,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • 在IntelliJ IDEA中使用Docker的開發(fā)指南

    在IntelliJ IDEA中使用Docker的開發(fā)指南

    這篇文章主要給大家介紹了在IntelliJ IDEA中使用Docker開發(fā)指南,文中通過圖文介紹的非常詳細(xì),對我們的使用Docker有一定的幫助,需要的朋友可以參考下
    2023-09-09
  • 5分鐘安裝docker詳細(xì)步驟

    5分鐘安裝docker詳細(xì)步驟

    官方推薦使用通過設(shè)置docker倉庫的方法來安裝,安裝和升級都簡單些,今天就來教大家5分鐘入手安裝docker教程超詳細(xì)的安裝步驟,感興趣的朋友一起看看吧
    2021-05-05
  • Docker搭建私有GitLab服務(wù)的方法

    Docker搭建私有GitLab服務(wù)的方法

    本文主要介紹了Docker搭建私有GitLab服務(wù)的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • Windows10?Docker?Desktop安裝過程

    Windows10?Docker?Desktop安裝過程

    Docker?Desktop是Docker公司推出的一款桌面應(yīng)用程序,它提供了一個用戶友好的界面,方便開發(fā)人員在本地環(huán)境中使用容器技術(shù),這篇文章主要介紹了Windows10?Docker?Desktop安裝過程,需要的朋友可以參考下
    2024-01-01
  • Docker中的四種網(wǎng)絡(luò)模式

    Docker中的四種網(wǎng)絡(luò)模式

    Docker網(wǎng)橋是宿主機(jī)虛擬出來的,并不是真實存在的網(wǎng)絡(luò)設(shè)備,外部網(wǎng)絡(luò)是無法尋址到的,這也意味著外部網(wǎng)絡(luò)無法通過直接Container-IP訪問到容器。本文詳細(xì)介紹了docker中的四種網(wǎng)絡(luò)模式,感興趣的小伙伴可以參考一下
    2023-04-04
  • 詳解Docker Compose配置文件參數(shù)

    詳解Docker Compose配置文件參數(shù)

    Compose是一個用于定義和運行多容器Docker的工具,本文主要介紹了Docker Compose配置文件參數(shù),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03

最新評論