3.重启docker守护进程
sudo systemctl stop docker
sudo systemctl start docker
4.检查配置是否生效
ps -ef|grep docker
如果配置生效,会在dockerd进程后边加上刚才配置的参数。
启动swarm模式
只需要在一个docker节点上初始化swarm集群, 其他节点加入这个集群就行了。
选择一台docker节点作为swarm模式的leader,运行
docker swarm init –advertise-addr 主机ip
按照提示信息在其他节点上执行命令加入swarm集群
在leader节点上执行docker node ls 查看节点信息
创建集群网络
1.在swarm集群中的任意一个节点上运行
docker network ls 查看当前网络状况
scope为local的网络只能作用于本机,下边创建swarm集群使用的网络。
2.运行 docker network create –driver overlay my-network
创建一个名为my-network的集群网络
再次运行 docker network ls,可以看到刚才创建的my-network ,scope为swarm,这个网络可以用于swarm模式,并让多个节点上的容器可以互通。
在swarm中创建service时可以通过 –network 网络名称 指定使用的网络。多个service如果使用同一个scope为swarm的network,可以通过service的名称互相通信。
docker swarm简单使用
下边简单介绍docker swarm的使用,有兴趣的可以查看docker官方文档进行深入了解。
下边的命令全部是在swarm的leader节点运行!!
docker service create –replicas 1 –name tomcat –publish 9090:8080 tomcat:latest
这里创建了一个名为tomcat 的service,swarm把容器封装为service,类似于kubernates中的pod,一个service是一个可供swarm调度的容器组合。
这里的–replicas 1指定了service的副本数。
–publish 9090:8080把容器中的8080端口发布到宿主机的9090端口
运行 docker service ls 查看当前的服务列表,可以看到有一个名为tomcat的服务。
运行 docker service ps tomcat 可以看到tomcat服务运行在哪个swarm节点,以及当前运行的状态。
切换到tomcat服务运行的节点,运行 docker ps 可以看到容器的ID,以及端口映射的情况。
运行 docker logs -f 容器ID 查看tomcat运行日志。
tomcat启动成功后,可以在浏览器中访问tomcat主页,地址是docker节点的ip(随便哪一个节点都可以),端口是9090,是在创建服务时指定的publish。
上边已经成功运行了一个tomcat服务,这里对这个服务进行扩展部署。
运行 docker service scale tomcat=2 把tomcat服务扩展为两个实例。
运行 docker service ls 可以看到tomcat服务的replicas变成了1/2,第二个实例启动成功之后会变为2/2。
运行 docker service ps tomcat 查看两个tomcat服务实例运行在哪个docker节点,以及运行状态。










