Chapter 3 解决Swarm管理Docker集群节点状态一直pending的问题

1 问题概述

在利用Swarm管理Docker集群时,很容易安装Swarm并将节点链接起来。但是,在集群中试图运行容器时,发现没有“健康”(healthy)的节点,导致容器无法再集群中运行。使用docker -H 10.4.230.62:2376 info命令(10.4.230.62是manage节点的ip)查看集群的节点状态,输出类似下图的信息

可以看到节点的状态是pending的。这个问题在网上也有很多人遇到,但是没有一个综合性的靠谱的解决方式,经过很长时间的摸索和大神的指导,终于解决了这个问题,其中有几个“坑”需要注意一下。

2 监听端口

 为了让 swarm manager 能够跟每台 swarm node 进行通信,集群中的每台节 点的 Docker daemon 都必须监听同一个网络接口。网上的通常做法是在/etc/default/docker文件中添加:DOCKER_OPTS="-H 0.0.0.0:2375 -H unix:///var/run/docker.sock" ,但是这种方式并没有起作用(可能是环境不同,本文使用的是centos 7系统),通过netstat命令可以查看端口情况,结果如下图所示

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值