之前我们写了好多篇关于docker的文章,但是环境都是单机的,也就是说只有一台docker引擎。
接下来这篇文章我们说一下docker集群及管理。
Docker官方为了解决多容器管理问题,推出了Docker Swarm工具,也是我们今天要说的内容。
Swarm简单介绍:
- Swarm首个版本在2014年12月初发布,2016年2月对架构进行重新设计,推出V2版本。
- 支持原生Docker API。
- 采用主从结构,通过Raft协议在多个管理节点中实现共识。
Swarm架构:
Swarm架构整体分为管理节点(Manager)和工作节点(Worker)
管理节点:响应外部对集群的操作请求,Swarm负责调度和管理容器,分发任务给工作节点。一个集群通常设置3、5、7个管理节点,但是必须为单数。
工作节点:负责执行具体任务。默认情况,管理节点自身也是工作节点。
- 用户可通过
docker node promote
将一个节点提升为管理节点;也可以通过docker node demote
将一个管理节点降级为工作节点。
Swarm核心概念:
- 服务(service):服务是为了支持编排所提出的概念,它是一系列复杂容器环境相互协作的统称。一个服务的声明包含容器的启动方式、副本数、环境变量、存储、配置、网络等一系列配置。用户用过Swarm将声明的服务实现。
服务分为全局服务和副本服务: 全局服务:每个工作节点都会运行一个任务 副本服务:按照指定副本数在集群中调度
- 任务:集群中最小的调度单位,即一个运行的应用容器。
- 服务外部访问:Swarm中支持入口负载均衡的映射模式。该模式每个服务都会被分配一个公开端口,该端口在集群中任意节点都可以访问到,并被保留给该服务。
搭建Swarm集群:
- Docker版本大于1.12,推荐最新稳定版
- 主机需要开放2377、4789、7946端口
原本我应该通过3个管理节点,若干工作节点来搭建集群,但是原谅我的本的性能,所以只能搭建一管理节点二工作节点的集群,但是并不妨碍讲解。
第一步:主备三台装有Docker引擎的主机,这点不说了,Docker搭建可以看我其他文章有这个。
第二步:初始化集群(1.12版本后已经默认集成到Docker中)
- 在管理节点上,通过以下命令初始化集群
- 如果多网卡需要加–advertise-addr参数指定网卡
docker swarm init --advertise-addr 192.168.10.3
- 节点加入集群需要用到以下信息
Swarm initialized: current node (hgya55eyardntljupfmpxsw3s) is now a manager. To add a worker to this swarm, run the following command: docker swarm join --token SWMTKN-1-457a1eursgbfc5m6lnxz224w6izmsdq82cv8rwfnj8ac6eujhb-5ph3idc72q66tpbaaic5bc6k7 192.168.10.3:2377 To add a manager to this swarm, run 'docker swarm join-token manager' and follow the instructions.
第三步:加入工作节点到集群(两个工作节点都要加入)
docker swarm join --token SWMTKN-1-457a1eursgbfc5m6lnxz224w6izmsdq82cv8rwfnj8ac6eujhb-5ph3idc72q66tpbaaic5bc6k7 192.168.10.3:2377
第四步***:如果加入管理节点到集群(如果你想有多个管理节点看这步,单节点跳过即可)
- 在管理节点上运行以下命令,然后想成为管理节点的主机上输入显示的结果即可
docker swarm join-token manager
第五步:查看节点
docker node ls
- 可查看所有节点,带星号为管理节点
ID HOSTNAME STATUS AVAILABILITY MANAGER STATUS ENGINE VERSION h55mmpjvnd3uh1jrkopuas400 centos7 Ready Active 20.10.7 hgya55eyardntljupfmpxsw3s * centos7 Ready Active Leader 20.10.7 y3ymp2sis7xwezzuhyhhy4h64 centos7 Ready Active 20.10.7
- 通过
docker info
可以查看集群信息,内容太多就不复制了。 - 如果想看的更明显,可以将主机名改成节点名,我忘了。。。
- 到此,一个集群算搭建完成。
使用Swarm:
Swarm中部署服务通常用两种方式:
一.通过docker service命令创建
- 通过
docker service
命令可以查看命令用法:
docker service Usage: docker service COMMAND Manage services Commands: create Create a new service inspect Display detailed information on one or more services logs Fetch the logs of a service or task ls List services ps List the tasks of one or more services rm Remove one or more services rollback Revert changes to a service's configuration scale Scale one or multiple replicated services update Update a service Run 'docker service COMMAND --help' for more information on a command.
- 创建一个服务:
docker service create --replicas 1 --name nginx nginx:1.16.1
- 查看服务
docker service ls
- 删除服务
docker service rm [服务名]
- 咳咳,我是想举例着,但是配置给小了,
二.通过docker stack
命令创建服务
这种方式运行的是docker-compose模板文件,关于docker-compose请查看我其他文章
- 可以在服务模板文件中添加deploy指令,并指定副本服务(replicated)数量
- 我们可以举一个nginx服务的例子
- 首先需要你安装docker-compose工具,关于这个工具使用:点击这里
- 模板文件内容:
version: '3' services: nginx: image: nginx:1.16.1 deploy: mode: replicated replicas: 2 restart: always port: - 80:80 volumes: - /data/nginx/:/etc/nginx - /data/webapps/www/:/usr/share/nginx/html/
- 需要手动创建模板中使用的目录
- 通过以下命令运行:
docker stack deploy -c docker-compose.yml nginx
- 通过任意节点的ip:80访问nginx服务
这篇可能有点问题,有问题的话可以留言问我,因为配置给小了,后面做的有点费劲。