docker的swarm实现容器群集

实验要求:可以上网的三台centos 7

实验步骤:

准备工作:

主机一(node1):

1安装docker环境:
2.设置ntp服务器的同步时间
vim /etc/ntp.conf
添加:
server 127.127.1.0
fudge 127.127.1.0 stratum 8
systemctl restart ntpd
其他两台服务器同步ntp服务器的时间
systemctl restart ntpd

3.修改主机名
临时修改:
hostname node1
bash
永久修改:
vim /etc/sysconfig/network
添加:
HOSTNAME=node1
其他两台服务器也修改主机名,分别为:node2 node3
4.修改hosts文件,用来解析主机。
vim /etc/hosts
192.168.6.106 node1
192.168.6.109 node2
192.168.6.110 node3
其他两台服务器做同样的配置
如:
scp /etc/hosts root@192.168.6.109:/etc/
scp /etc/hosts root@192.168.6.110:/etc/
验证:ping node2
ping node3
可以通过主机名进行网络的连通性测试

5.清除防火墙的默认规则,关闭selinux,开启docke服务
iptables -F
iptables –L
setenforce 0
systemctl restart docker
其他两台服务器做同样的配置

6.配置ssh远程访问,使用密钥的方式创建链接,则不需要密码了。
生成密钥,一路下一步即可
ssh-keygen
将公钥传给其他两台服务器:
ssh-copy-id -i /root/.ssh/id_rsa.pub root@192.168.6.109
ssh-copy-id -i /root/.ssh/id_rsa.pub root@192.168.6.110
验证:可以通过主机名链接其他两台服务器
ssh node3

 

正式开始:

7.创建docker群集的领导者和工作者,node1作为领导者进行配置。

(1)初始化swarm指定群集的通讯IP地址,此时6.106成为领导者

docker swarm init --advertise-addr 192.168.6.106

(2)可查看当前节点成员

docker node ls  

(3)根据领导发话将后续节点加入群集,根据下面的这段代码可以将其他的两台服务器加入到swarm群集中,

docker swarm join \

--token SWMTKN-1-3vxn0lnobabqwngyxi67hxtf74qi00fciy86lfr2

g931ziv2ro-0varh1mcqoe3pi4ak9qzo5deo \

192.168.6.105:2377

 

docker  node  ls   //查看swarm群集的成员

4)分别在其他两台服务器上执行这段代码,将其加入到群集中,如果加不进去的检查防火墙策略清空没有

(5)再次查看群集节点信息

docker node ls

 

8.开启ipv4转发功能

vim /etc/sysctl.conf

net.ipv4.ip_forward = 1

net.ipv4.ip_forward_use_pmtu = 0

sysctl –p

其他两台服务做同样的配置

如:

scp /etc/sysctl.conf node2:/etc

scp /etc/sysctl.conf node3:/etc

并分别到两台服务器上进行内核文件的刷新

 

9.拉取registry:2镜像,用来做私有仓库,

(1)公网拉取

docker  search  registry

docker pull registry:2

(2)离线包              //次实验推荐的步骤

docker load -i registry2.tar    //解压tar包成镜像

docker images

创建私有仓库的物理目录 

mkdir /lpc/xixi –p    

启动私有库用的容器

docker run -itd -p 5000:5000 --restart=always -v /lpc/xixi/registry/:/var/lib/registry --name registry registry:2

 

docker ps

 

验证容器中的私有库目录是否存在

curl 192.168.6.106:5000/v2/_catalog

 

发布私有仓库其他主机可以访问

注意:为了防止改坏这份文件,可以先做备份

cp /usr/lib/systemd/system/docker.service /yum/

然后进行修改:

vim /usr/lib/systemd/system/docker.service

ExecStart=后面的选项最下面添加换行符和新选项 --insecure-registry 192.168.6.106:5000

如:

 

 

守护进程重新加载

systemctl daemon-reload

重启服务

service docker restart

验证:

确保docker ps后容器还在,否则就是配置有误docker ps

 

其他两台服务器的配置,

将修改后的docker.service文件分别复制都其他两台服务器的相同的目录路径下,为了可以访问领导者的私有库,并在每台服务器上启动守护进程和重启docker服务。

scp /usr/lib/systemd/system/docker.service node2:/usr/lib/systemd/system/

scp /usr/lib/systemd/system/docker.service node3:/usr/lib/systemd/system/

 

systemctl daemon-reload

service docker restart

 

10.拉取或添加nginx镜像

docker pull nginx 或

docker load -i nginx2.tar

docker images

为这个镜像添加易识别的私有标签,来区别是公有的还是私有的

docker tag nginx 192.168.6.106:5000/nginx

docker images

上传私有镜像到刚才做好的私有仓库

docker push 192.168.6.106:5000/nginx

再次查看私有仓库目录

curl 192.168.6.106:5000/v2/_catalog

也可以去其他节点试着pull一下192.168.6.106:5000/nginx,但是拉完别忘记删掉一会再推

 

11.添加群集专属网络

docker network create --driver overlay my-network

docker network ls

 

12. 安装swarm群集图形化监视工具

拉取镜像

docker pull docker.io/dockersamples/visualizer

或者使用离线包   //本实验推荐

docker load -i visualizer.tar

docker images

先给离线镜像做个标记,用来区别公有镜像。

docker tag dockersamples/visualizer 192.168.6.106:5000/visualizer

docker images

将这个镜像发布到私有仓库

docker push 192.168.6.106:5000/visualizer

curl 192.168.6.106:5000/v2/_catalog

 

13. 本地运行图形监视软件所在镜像成为容器

docker run -itd -p 8888:8080 -e HOST=192.168.6.106 -v /var/run/docker.sock:/var/run/docker.sock --name visualizer 192.168.6.106:5000/visualizer

docker ps

 

14.验证图形监控页面

Firefox  192.168.6.106:8888

 

15. 创建swarm群集服务,3个容器跑nginx

docker service create --replicas 3 --network my-network --name web -p 80:80 192.168.6.106:5000/nginx

docker ps

 

查看服务节点信息

docker service ps web

查看群集列表

docker service ls

 

验证:

重新访问后者刷新游览器首页

Firefox  192.168.6.106:8888

 

16.增加容器为5个

在管理者上执行:

docker service scale web=5

 

查看服务节点信息

docker service  ps web

查看群集列表

docker service  ls

重新访问后者刷新游览器首页

 

17.验证

(1)在各个nginx容器中修改主页信息,测试群集效果

进入正在运行的nginx容器里,添加不同的主页信息

docker  exec  -it  容器ID  /bin/bash

echo "<h1>wwww</h1>"  > /usr/share/nginx/html/index.html

 

(2)关闭node3的docker服务,会发现这个容器被转移到了其他节点,重启打开node3,再把转移走的容器删掉,容器又会转移会node3

 

注意:在关闭node3后,其他两台服务器会通过自己内部的调度器将node3上的容器运行在其他两台上,当重新启动node3时,并不会自动切回来,需要到其他两台服务器上,查看容器列(docker  ps)表,通过容器运行的时间来确定那几台是刚加进来的,刚加进来的就是node3的容器,删除他,就会自动回到node3上。

18.群集管理常用命令

开启节点docker node update --availability active node3

关闭节点docker node update --availability drain node3

在界节点上申请退出群集

docker swarm leave -f

 

 

 

 

node2node3

 

1.配置hosts文件,由于是从node1的管理者上直接通过scp传过来的,所以直接查看即可。

cat  /etc/hosts

 

2. 清除防火墙的默认规则,关闭selinux,开启docke服务

iptables –F

setenforce 0

systemctl restart docker

 

3.这是在管理者node1生成的加入swarm群集的代码,在工作者服务器上执行就可以加入群集。

docker swarm join \

--token SWMTKN-1-3vxn0lnobabqwngyxi67hxtf74qi00fciy86lfr2

g931ziv2ro-0varh1mcqoe3pi4ak9qzo5deo \

192.168.6.105:2377

如果后来忘记了

用Docker swarm join-token worker 重新查看加入命令

 

4.开启ipv4转发功能,

vim /etc/sysctl.conf

net.ipv4.ip_forward = 1

net.ipv4.ip_forward_use_pmtu = 0

sysctl –p

 

5.用来访问管理者私有仓库的配置文件,和node1上的一摸一样,通过scp就可以分别传到node2和node3上,查看即可

cat /usr/lib/systemd/system/docker.service

但是需要开启守护进程和重启docker服务

systemctl daemon-reload

service docker restart

 

6.当node1的私有仓库搭建好之后,并上传镜像后,可以在node2,3上测试是否可以使用,拉取镜像。

docker pull 192.168.6.106:5000/nginx

docker images

 

7.修改本服务器上的容器的nginx默认首页文件,用来做群集调度测试。

 

 

添加:

经理可以加副经理

docker node promote node2

删除副经理

docker node demote node2

docker  info   //可以查看其经理的信息

posted @ 2018-03-12 15:48  Leonardo-li  阅读(902)  评论(0编辑  收藏  举报