【Docker】创建 swarm 集群

目录

[1. 更改防火墙设置](#1. 更改防火墙设置)

[2. 安装 Docker 组件](#2. 安装 Docker 组件)

[3. 启动 Docker 服务,并检查服务状态。](#3. 启动 Docker 服务,并检查服务状态。)

[4. 修改配置文件,监听同一端口号。](#4. 修改配置文件,监听同一端口号。)

[5. 下载 Swarm 组件](#5. 下载 Swarm 组件)

[6. 创建集群,加入节点](#6. 创建集群,加入节点)

[7. 启动集群](#7. 启动集群)

[8. 查询集群节点信息](#8. 查询集群节点信息)

[9. 查询集群具体信息](#9. 查询集群具体信息)

[10. 查询集群活动状态](#10. 查询集群活动状态)

[11. 在集群内部署应用,并查询集群信息。](#11. 在集群内部署应用,并查询集群信息。)

[12. 查询集群内部容器活动状态。](#12. 查询集群内部容器活动状态。)

[13. 在集群内创建应用,实现自动部署。](#13. 在集群内创建应用,实现自动部署。)


1. 更改防火墙设置

bash 复制代码
hostnamectl set-hostname node1  # 设置主机名为"node1" 需要重启虚拟机生效

iptables -F   # 清除防火墙规则中的所有过滤规则

iptables -X   # 删除防火墙中用户定义的链

iptables -Z   # 将防火墙计数器归零,用于统计流量

/usr/sbin/iptables-save  # 保存当前的防火墙规则
bash 复制代码
vi /etc/sysctl.conf
bash 复制代码
net.ipv4.ip_forward = 1
net.ipv4.conf.default.rp_filter = 0
net.ipv4.conf.all.rp_filter = 0
"/etc/sysctl.conf" 8L, 318C written
# sysctl -p
net.ipv4.ip_forward = 1
net.ipv4.conf.default.rp_filter = 0
net.ipv4.conf.all.rp_filter = 0

2. 安装 Docker 组件

bash 复制代码
yum install -y docker-io

3. 启动 Docker 服务,并检查服务状态。

bash 复制代码
systemctl start docker

systemctl status docker

4. 修改配置文件,监听同一端口号。

bash 复制代码
vi /usr/lib/systemd/system/docker.service

修改之前可以先备份一下!添加下图所示配置

bash 复制代码
/usr/bin/dockerd-current -H tcp://0.0.0.0:2375 -H unix://var/run/docker.sock\

修改配置以后重启服务,如果重启失败,那么就是配置文件写错了,再仔细检查一下。

bash 复制代码
systemctl daemon-reload

systemctl restart docker

netstat -anpl | grep 2375
bash 复制代码
sudo systemctl restart docker

5. 下载 Swarm 组件

bash 复制代码
docker pull swarm
bash 复制代码
cd /root

6. 创建集群,加入节点

bash 复制代码
vi cluster 
bash 复制代码
192.168.9.10:2375 # ip地址用虚拟机的
192.168.9.13:2375 # 克隆第一台虚拟机

7. 启动集群

bash 复制代码
docker run -d -p 2376:2375 -v $(pwd)/cluster:/tmp/cluster swarm manage file:///tmp/cluster

8. 查询集群节点信息

bash 复制代码
docker run --rm -v $(pwd)/cluster:/tmp/cluster --privileged swarm list file:///tmp/cluster

1. 获取加入集群所需的令牌!!

bash 复制代码
docker swarm join-tocken worker

2. 复制上面的输出,在第二台虚拟机执行加入命令

bash 复制代码
docker swarm join --token SWMTKN-1-30wggx60wr9qu1inn66kthwl6wtoxhbclhsv1nbzb73bbf6m8a-9a57fl4du8bhv5sfo48rz0bwn 192.168.9.10:2377

3. 查看第一台虚拟机

bash 复制代码
​​​​​​​docker node ls

9. 查询集群具体信息

bash 复制代码
docker -H 192.168.9.10:2375 info

10. 查询集群活动状态

bash 复制代码
docker ps -a

11. 在集群内部署应用,并查询集群信息。

bash 复制代码
docker -H 192.168.9.10:2375 run -idt busybox
bash 复制代码
 docker -H 192.168.9.10:2375 info

12. 查询集群内部容器活动状态。

bash 复制代码
docker -H 192.168.9.10:2375 ps -a

13. 在集群内创建应用,实现自动部署。

bash 复制代码
docker -H 192.168.9.10:2375 run -idt busybox
bash 复制代码
docker -H 192.168.9.10:2375 run -idt busybox
bash 复制代码
docker -H 192.168.9.10:2375 ps -a
相关推荐
武子康3 小时前
调查研究-183 Apple container:Mac 上用轻量 VM 跑 Linux 容器,Swift 会改写本地容器体验吗?
docker·容器·apple
A小辣椒1 天前
TShark:Wireshark CLI 功能
linux
A小辣椒1 天前
TShark:基础知识
linux
AlfredZhao1 天前
OCI 明明分配了 200G 系统盘,为什么 df 只看到 30G?
linux·oci
AlfredZhao2 天前
vi 删除指定范围的行,不用再反复按 dd
linux·vi
用户9718356334662 天前
银河麒麟 KY10 申威(SW64) 安装 nginx-1.16.1-2.p01.ky10.sw_64.rpm 详细步骤
linux
猪脚踏浪2 天前
linux 拷贝文件或目录到指定的位置
linux
摇滚侠3 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
bush43 天前
嵌入式linux学习记录十四、术语
linux·嵌入式
载数而行5203 天前
Linux 11 动态监控指令top
linux