Loading

Docker-集群swarm(5)

 Docker集群的概念

   群集是一组运行Docker并加入集群的计算机。在此之后,您继续运行您习惯使用的Docker命令,但现在它们由群集管理器在群集上执行群中的机器可以是物理的或虚拟的。加入群组后,它们被称为节点

Swarm管理器可以使用多种策略来运行容器,例如“最节点的节点” - 它使用容器填充利用率最低的机器。,它确保每台机器只获得指定容器的一个实例。您指示swarm管理器在Compose文件中使用这些策略。

群集管理器是群中唯一可以执行命令的机器,或者授权其他机器作为工作者加入群集工人只是在那里提供能力,没有权力告诉任何其他机器它能做什么和不能做什么。

 

1. 安装Docker Machine

安装

$ base=https://github.com/docker/machine/releases/download/v0.16.0 &&
  curl -L $base/docker-machine-$(uname -s)-$(uname -m) >/tmp/docker-machine &&
  sudo install /tmp/docker-machine /usr/local/bin/docker-machine

  

检查安装版本

[root@docker ~]# docker-machine version
docker-machine version 0.16.0, build 702c267f

  

安装bash完成脚本

Machine存储库提供了几个bash脚本,可添加以下功能:

  • 命令完成
  • 一个在shell提示符下显示活动计算机的函数
  • 一个函数包装器,它添加一个docker-machine use子命令来切换活动机器
base=https://raw.githubusercontent.com/docker/machine/v0.16.0
for i in docker-machine-prompt.bash docker-machine-wrapper.bash docker-machine.bash
do
  sudo wget "$base/contrib/completion/bash/${i}" -P /etc/bash_completion.d
done

  使其生效

source /etc/bash_completion.d/docker-machine-prompt.bash

要启用docker-machineshell提示,请添加 $(__docker_machine_ps1)到您的PS1设置中~/.bashrc

PS1='[\u@\h \W$(__docker_machine_ps1)]\$ '

  

安装VirtualBox

参考: yum安装VirtualBox

如果是在Vmare的机器中还需要开启虚拟化

 

docker-machine使用VirtualBox驱动程序创建几个VM 

docker-machine create --driver virtualbox myvm1
docker-machine create --driver virtualbox myvm2

  

列出计算机并获取其IP地址

[root@docker ~]# docker-machine ls
NAME    ACTIVE   DRIVER       STATE     URL                         SWARM   DOCKER     ERRORS
myvm1   -        virtualbox   Running   tcp://192.168.99.100:2376           v18.09.1   
myvm2   -        virtualbox   Running   tcp://192.168.99.101:2376           v18.09.1   

  

2. 初始化SWARM并添加节点

第一台机器充当管理器,第二台是工人节点,它执行管理命令并验证工作节点加入群。

您可以使用命令向VM发送命令docker-machine ssh指示myvm1 成为一个swarm管理器docker swarm init并查找如下输出:

[root@docker ~]#docker-machine ssh myvm1 "docker swarm init --advertise-addr 192.168.99.100"
Swarm initialized: current node (kx0ou7byih7sjb4hudxearizw) is now a manager.

To add a worker to this swarm, run the following command:

    docker swarm join --token SWMTKN-1-3ofjl4coq8n9z2bw6t4nnr8zzuhrg7bmlf94f59ybjee74fs0d-dr5g7ec9nzkb2ypj9q3275l3n 192.168.99.100:2377

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

  端口2366和2377

  • 2377:群集管理端口
  • 2376:Docker守护程序端口

将第二台虚拟机加入集群

[root@docker ~]#docker-machine ssh myvm2 "docker swarm join --token SWMTKN-1-3ofjl4coq8n9z2bw6t4nnr8zzuhrg7bmlf94f59ybjee74fs0d-dr5g7ec9nzkb2ypj9q3275l3n 192.168.99.100:2377"
This node joined a swarm as a worker.

  

查看集群中的节点

[root@docker ~]#docker-machine ssh myvm1 "docker node ls"
ID                            HOSTNAME            STATUS              AVAILABILITY        MANAGER STATUS      ENGINE VERSION
kx0ou7byih7sjb4hudxearizw *   myvm1               Ready               Active              Leader              18.09.1
yqg18tj1ujx13eb47sb10ozvk     myvm2               Ready               Active                                  18.09.1

  

离开群,在需要离开的节点运行

docker swarm leave

  

3. 在集群中部署应用程序

为管理节点(myvm1)配置shell

到目前为止,您已经将Docker命令包装在docker-machine ssh与VM通信中。另一种选择是运行docker-machine env <machine>以获取并运行一个命令,该命令将当前shell配置为与VM上的Docker守护程序通信。此方法适用于下一步,因为它允许您使用本地docker-compose.yml文件“远程”部署应用程序,而无需将其复制到任何位置。

[root@docker ~]#docker-machine env myvm1
export DOCKER_TLS_VERIFY="1"
export DOCKER_HOST="tcp://192.168.99.100:2376"
export DOCKER_CERT_PATH="/root/.docker/machine/machines/myvm1"
export DOCKER_MACHINE_NAME="myvm1"
# Run this command to configure your shell: 
# eval $(docker-machine env myvm1)
[root@docker ~]#eval $(docker-machine env myvm1)
[root@docker ~ [myvm1]]#docker-machine ls
NAME    ACTIVE   DRIVER       STATE     URL                         SWARM   DOCKER     ERRORS
myvm1   *        virtualbox   Running   tcp://192.168.99.100:2376           v18.09.1   
myvm2   -        virtualbox   Running   tcp://192.168.99.101:2376           v18.09.1 

  可以看见myvm1变成了活动状态

 

取消当前shell

eval $(docker-machine env myvm1)

  

在swarm管理器上部署应用程序
[root@docker ~ [myvm1]]#docker stack deploy -c docker-compose.yml getstartedlab
Creating network getstartedlab_webnet
Creating service getstartedlab_web

 

可以通过下面的命令查看服务已经分布在myvm1和myvm2上了

[root@docker ~ [myvm1]]#docker stack ps getstartedlab
ID                  NAME                  IMAGE               NODE                DESIRED STATE       CURRENT STATE           ERROR               PORTS
r2bg0k9j68br        getstartedlab_web.1   scottcho/flask:v1   myvm1               Running             Running 3 minutes ago                       
kumrzfmznjmq        getstartedlab_web.2   scottcho/flask:v1   myvm2               Running             Running 2 minutes ago                       
1w3p5qe3fbhf        getstartedlab_web.3   scottcho/flask:v1   myvm1               Running             Running 3 minutes ago                       
bxlvev660m1o        getstartedlab_web.4   scottcho/flask:v1   myvm2               Running             Running 2 minutes ago                       
62jts8h2qplt        getstartedlab_web.5   scottcho/flask:v1   myvm2               Running             Running 2 minutes ago      

  

访问服务

[root@docker ~ [myvm1]]#curl http://192.168.99.100:4000
<h3>Hello World!</h3><b>Hostname:</b> f612eb9ae8f3<br/><b>Visits:</b> <i>cannot connect to Redis, counter disabled</i>[root@docker ~ [myvm1]]#curl http://192.168.99.101:4000
<h3>Hello World!</h3><b>Hostname:</b> 37e0a0449988<br/><b>Visits:</b> <i>cannot connect to Redis, counter disabled</i>[root@docker ~ 

  

内部网络图

 

 停止和启动VM

 

docker-machine stop myvm2
docker-machine start myvm2

  

 

 

   

 

posted @ 2019-01-24 10:36  头痛不头痛  阅读(403)  评论(0编辑  收藏  举报