docker-swarm
创建Swarm集群
docker swarm init --advertise-addr 192.168.31.43
# --advertise-addr参数表示其它swarm中的worker节点使用此ip地址与manager联系。
docker swarm init --advertise-addr enp0s8
# --advertise-addr 该参数也可使用网卡名
查询加入Swarm集群的命令
docker swarm join-token manager
离开Swarm集群
docker swarm leave
给node节点添加标签
# docker node update --label-add client=true <node-name>
docker node update --label-add func=nginx worker1
创建网络
- overlay网络
docker network create middleware -d overlay --scope swarm
# 指定子网范围(PS: 防止和宿主机IP冲突(error: No route to host))
docker swarm init --default-addr-pool 192.168.0.0/16
部署命令
docker stack up -c docker-compose.yml rmq
docker swarm 端口映射问题
<serviceName>:
ports:
- target: 6379
published: 6379
protocol: tcp
mode: host
docker swarm 端口开放
# Before starting, verify its status:
systemctl status firewalld
# It should not be running, so start it:
systemctl start firewalld
# Then enable it so that it starts on boot:
systemctl enable firewalld
# Afterwards, reload the firewall:
firewall-cmd --reload
# Then restart Docker.
systemctl restart docker
Note: If you make a mistake and need to remove an entry, type:
firewall-cmd --remove-port=port-number/tcp —permanent.
######On the node that will be a Swarm manager, use the following commands to open the necessary ports: firewall-cmd --add-port=2376/tcp --permanent
firewall-cmd --add-port=2377/tcp --permanent
firewall-cmd --add-port=7946/tcp --permanent
firewall-cmd --add-port=7946/udp --permanent
firewall-cmd --add-port=4789/udp --permanent######Then on each node that will function as a Swarm worker, execute the following commands: firewall-cmd --add-port=2376/tcp --permanent
firewall-cmd --add-port=7946/tcp --permanent
firewall-cmd --add-port=7946/udp --permanent
firewall-cmd --add-port=4789/udp --permanent
# docker machine
firewall-cmd --add-port=2376/tcp --permanent
# manager
firewall-cmd --add-port=2377/tcp --permanent
# communication among nodes (container network discovery).
firewall-cmd --add-port=7946/tcp --permanent
firewall-cmd --add-port=7946/udp --permanent
# overlay network traffic (container ingress networking).
firewall-cmd --add-port=4789/udp --permanent
# 2376 用于docker machine 在实体机,一般不需要。
docker swarm 端口开放参考链接
# xml开放端口
# 通过以下命令查找xml文件存放路径(这里查找的是系统存放路径)
find / -name ssh.xml
# 查找docker相关xml
ls | grep docker
# 如果有(docker-swarm.xml)则可直接开启它,可省去下面自己新建文件的过程
vi /etc/firewalld/services/docker.xml # 这个是用户存放路径,可能不在这个路径,可以通过上面那条命令查找路径
<?xml version="1.0" encoding="utf-8"?>
<service>
<short>docker</short>
<description>docker daemon for remote access</description>
<port protocol="tcp" port="2376"/>
<port protocol="tcp" port="2377"/> # manager节点才需要
<port protocol="tcp" port="7946"/>
<port protocol="udp" port="7946"/>
<port protocol="udp" port="4789"/>
</service>
# 查看默认zone(一般是public)
firewall-cmd --get-default-zone
# 在zone中加入这个service
firewall-cmd --zone=public --add-service=docker --permanent
# 重新加载
firewall-cmd --reload
# 详见linux.md 和 firewalld.md文件