基于docker1.12创建swarm集群

简介:        Docker 1.12 在 2016 年 7 月 28 日正式 GA,除了大量的在使用上的改进和 bug 修复外,最引人瞩目的是Docker原生支持了 Swarm 模式,而不是将Swarm作为一个容器对集群进行管理。 而docker1.12的操作命令并不向下兼容,本文描述了基于doc

       Docker 1.12 在 2016 年 7 月 28 日正式 GA,除了大量的在使用上的改进和 bug 修复外,最引人瞩目的是Docker原生支持了 Swarm 模式,而不是将Swarm作为一个容器对集群进行管理。

而docker1.12的操作命令并不向下兼容,于是过去所有创建swarm集群的文档都不能参考了,本文描述了基于docker1.12版本创建Swarm集群的过程。


1、主机环境

在阿里云上申请三个vpc网络的ECS,安装centos7.0的镜像,ip和角色分配如下:

192.168.0.18 manager

192.168.0.19 worker

192.168.0.20 worker


2、docker安装


参考官方文档:https://docs.docker.com/engine/installation/linux/centos/


1)首先确认内核版本,内核版本至少要3.10以上

uname -r


2)增加docker的yum源配置

tee /etc/yum.repos.d/docker.repo <<-'EOF'

[dockerrepo]

name=Docker Repository

baseurl=https://yum.dockerproject.org/repo/main/centos/7/

enabled=1

gpgcheck=1

gpgkey=https://yum.dockerproject.org/gpg

EOF


3)yum安装docker

yum install libdevmapper* -y

yum install docker-engine -y


4)启动docker

service docker start

ps auxwww | grep -i docker



5)配置阿里云的docker源镜像加速

登录阿里云账号,开通阿里云的容器服务

通过以下地址确认阿里云账号专属的加速器地 https://cr.console.aliyun.com/#/docker/booster 

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

原内容:ExecStart=/usr/bin/dockerd 

修改成 ExecStart=/usr/bin/dockerd --registry-mirror=https://被替换内容.mirror.aliyuncs.com

systemctl daemon-reload 

service docker restart



3、docker原生swarm的概念普及

1)manager与worker

一个集群最多有3-7个manager,其他都是worker

manager节点:负责对任务进行调度和其它管理任务,多个管理节点通过 Raft 协议组成集群;

worker节点:负责运行具体的任务,管理节点可以同时作为工作节点

2)server包括两种类型:

复制服务(replicated services):类似 k8s 中复制集的概念,保持一定数量的相同任务在集群中运行;

全局服务(global services):类似 k8s 中 daemon 的概念,每个工作节点上运行一个。

一个服务由多个任务组成,一个任务即一个运行的容器。


4、swarm集群的创建


参考文档 https://docs.docker.com/engine/reference/commandline/swarm_init/

192.168.0.18 manager 

192.168.0.19 worker

192.168.0.20 worker


初始化swarm集群

docker swarm init --advertise-addr 192.168.0.18

Swarm initialized: current node (4bl82cxazydg7y86kzbmfief3) is now a manager.


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

docker swarm join \

--token SWMTKN-1-1mtdmuzd5n5il70r7mm1sg66rnr6ov38dumfdon408sq4nmqgz-0gej194ntpt73v3zhqiy0sq31 \

192.168.0.18:2377


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

docker swarm join \

--token SWMTKN-1-1mtdmuzd5n5il70r7mm1sg66rnr6ov38dumfdon408sq4nmqgz-3pnkjncrpfh4d94aghk2a9h2w \

192.168.0.18:2377


manager上查看当前集群节点

docker node ls

ID                           HOSTNAME      STATUS  AVAILABILITY  MANAGER STATUS

4bl82cxazydg7y86kzbmfief3 *  iZ23ogad28gZ  Ready   Active        Leader




192.168.0.19/192.168.0.20

docker swarm join --token SWMTKN-1-1mtdmuzd5n5il70r7mm1sg66rnr6ov38dumfdon408sq4nmqgz-0gej194ntpt73v3zhqiy0sq31 192.168.0.18:2377


manager上查看集群状态

docker node ls

ID                           HOSTNAME      STATUS  AVAILABILITY  MANAGER STATUS

4bl82cxazydg7y86kzbmfief3 *  iZ23ogad28gZ  Ready   Active        Leader

avd0uhd0mjt939sz8pje1mdyq    iZ232tm0nizZ  Ready   Active        

dpqqdnkcagubmank7qw9i7jhz    iZ23h6u54mvZ  Ready   Active 


 

在192.168.0.20上,将节点手动脱离

docker swarm leave

Node left the swarm.



回到manager上查看集群状态

docker node ls

docker node ls

ID                           HOSTNAME      STATUS  AVAILABILITY  MANAGER STATUS

4bl82cxazydg7y86kzbmfief3 *  iZ23ogad28gZ  Ready   Active        Leader

avd0uhd0mjt939sz8pje1mdyq    iZ232tm0nizZ  Ready   Active        

dpqqdnkcagubmank7qw9i7jhz    iZ23h6u54mvZ  Down    Active  




围绕集群和服务进行管理还涉及到如下的命令,可以直接参考官方文档

https://docs.docker.com/engine/reference/

swarm init

swarm join

service create

service inspect

service ls

service rm

service scale

service ps

service update




目录
相关文章
|
1月前
|
消息中间件 监控 RocketMQ
Docker部署RocketMQ5.2.0集群
本文详细介绍了如何使用Docker和Docker Compose部署RocketMQ 5.2.0集群。通过创建配置文件、启动集群和验证容器状态,您可以快速搭建起一个RocketMQ集群环境。希望本文能够帮助您更好地理解和应用RocketMQ,提高消息中间件的部署和管理效率。
261 91
|
3月前
|
Prometheus 监控 Cloud Native
如何使用Prometheus监控Docker Swarm集群的资源使用情况?
还可以根据实际需求进行进一步的配置和优化,如设置告警规则,当资源使用超出阈值时及时发出警报。通过这些步骤,能够有效地使用 Prometheus 对 Docker Swarm 集群的资源进行监控和管理。
132 8
|
3月前
|
Prometheus 监控 Cloud Native
如何监控Docker Swarm集群的性能?
如何监控Docker Swarm集群的性能?
213 8
|
3月前
|
调度 开发者 Docker
Docker Swarm
Docker Swarm 为容器化应用的部署和管理提供了一种高效、可靠的方式,使开发者能够更轻松地构建和运行分布式应用。随着容器技术的不断发展,Docker Swarm 在企业级应用中的应用也将越来越广泛。
93 8
|
3月前
|
监控 Docker 容器
Docker Swarm集群的扩展与缩容策略,涵盖其意义、方法、步骤及注意事项
本文深入探讨了Docker Swarm集群的扩展与缩容策略,涵盖其意义、方法、步骤及注意事项,旨在帮助用户高效管理集群资源,适应业务变化,确保服务稳定性和资源优化。
104 6
|
4月前
|
Kubernetes 负载均衡 调度
Docker Swarm 核心概念及详细使用
Docker Swarm 是 Docker 的原生集群管理工具,用于将多个 Docker 主机整合成一个虚拟主机,提供集群管理和调度功能。其核心特点包括集群管理、容错与高可用性、负载均衡、声明式服务模型、服务发现和安全性。本文档详细介绍了 Docker Swarm 的安装配置、服务部署、节点管理、网络配置及故障模拟等关键操作,适用于中小型项目或对 Kubernetes 复杂性有所顾虑的用户。
314 6
|
4月前
|
应用服务中间件 nginx Docker
Docker Swarm、Docker Stack和Portainer的使用
Docker Swarm、Docker Stack 和 Portainer 各有其独特的功能和优势。Docker Swarm 适用于分布式服务的管理和编排,Docker Stack 便于多容器应用的定义和部署,而 Portainer 提供了直观的 UI,简化了 Docker 环境的管理。结合使用这些工具,可以大大提高容器化应用的部署和管理效率。希望本文对您理解和应用这些工具有所帮助。
272 5
|
4月前
|
API Docker 容器
【赵渝强老师】构建Docker Swarm集群
本文介绍了如何使用三台虚拟主机构建Docker Swarm集群。首先在master节点上初始化集群,然后通过特定命令将node1和node2作为worker节点加入集群。最后,在master节点上查看集群的节点信息,确认集群构建成功。文中还提供了相关图片和视频教程,帮助读者更好地理解和操作。
|
4月前
|
调度 Docker 容器
【赵渝强老师】Docker Swarm集群的体系架构
Docker Swarm自1.12.0版本起集成至Docker引擎,无需单独安装。它内置服务发现功能,支持跨多服务器或宿主机创建容器,形成集群提供服务。相比之下,Docker Compose仅限于单个宿主机。Docker Swarm采用主从架构,Swarm Manager负责管理和调度集群中的容器资源,用户通过其接口发送指令,Swarm Node根据指令创建容器运行应用。
|
9天前
|
监控 关系型数据库 MySQL
zabbix7.0.9安装-以宝塔安装形式-非docker容器安装方法-系统采用AlmaLinux9系统-最佳匹配操作系统提供稳定运行环境-安装教程完整版本-优雅草卓伊凡
zabbix7.0.9安装-以宝塔安装形式-非docker容器安装方法-系统采用AlmaLinux9系统-最佳匹配操作系统提供稳定运行环境-安装教程完整版本-优雅草卓伊凡
87 30