Docker运维教程(12)集群编排工具swarm
一、什么是Swarm
Swarm和Compose一样是一个容器编排工具,但是相比Compose它可以运行在多个服务器上,可以为Docker实现集群化,更适合生产环境使用
二、安装和配置Swarm
1、在docker 1.12以后swarm已经整合进了docker中,不需要单独再安装
2、Swarm集群中有一个服务器作为Manager角色来管理集群中的容器资源,其他服务器作为Node角色提供容器。所以选取一台节点作为Manager初始化集群
docker swarm init --listen-addr 192.168.1.100 --advertise-addr 192.168.1.100 #写上主节点的IP
3、命令执行完成后会输出一个提示,写明了其他node节点需要执行的命令,只需要在每个node节点执行即可。命令大致如下:
docker swarm join --token SWMTKN-1-37asvgkjwbqjkbwqjktbjk21bj215b1jk25b1jb 192.168.1.100:2377
4、查看集群节点状态
docker node ls
5、如果节点需要退出集群
docker swarm leave
三、在Swarm集群部署应用(相关命令都在Manager执行)
1、首先使用Dockerfile构建镜像并上传到Dockerhub中,这样可以保证每个节点能访问到镜像
docker login docker build -t tanglu86/nginx:v2 . docker push tanglu86/nginx:v2
2、在swarm中service对应container,所以通过创建service可以将镜像自动分发到集群中不同节点上,Swarm默认会使用VIP方式进行轮询负载均衡
docker service create nginx:latest #创建一个service,这里没有使用任何的选项,然后会从docker hub上拉取nginx镜像进行创建 docker service create -p 7788:80 --replicas 3 --name swarm_test tanglu86/nginx:v2 #从指定仓库拉取指定镜像并进行了端口转发等配置 docker service ls #查看集群中service所属节点及副本信息等 docker service ps swarm_test #查看指定service情况,比如分布在哪个节点,这里查看的是swarm_test
3、容器副本扩容,如果有容器发生宕机或者关闭导致replicas数下降的话,会自动在其他节点上创建容器,保持replicase数量
docker service scale swarm_test=5 docker service ls #查看replicas数量
4、删除集群中的容器
docker serivce rm nginx docker serivce ls
5、更新容器版本,将swarm_test这个容器升级到nginx:v3版本,升级是一个容器一个容器的完成
docker service update --image tanglu86/nginx:v3 swarm_test
6、回滚容器到上一个版本
docker service update --rollback swarm_test
版权声明:本文章版权归数据库运维网(www.ywdba.cn)所有。如需引用本站内容,请注明来源及作者。
评论