自备 etc + swarm集群

安装Swarm集群


环境信息


服务器:


10.141.59.115 centos-node1
10.141.60.136 centos-node2
10.141.37.71 centos-node3
集群信息:


etc服务器: 10.141.59.115:2379
swarm manage: 10.141.60.136:3376
swarm-node1: 10.141.59.115:2375
swarm-node2: 10.141.60.136:2375
swarm-node3: 10.141.37.71:2375
准备


在所有的机器上安装dokcer
在centos-node1 上docker pull ystyle/etcd (官方的下载不了,自己做了个一样的)
在所有机器上dokcer pull swarm
以上三步可以用docker-machine完成
开放所有机器的2375端口, centos-node1的2379端口,centos-node2的3376端口
安装etcd k-v数据库


在centos-node1上执行:


Shell
# 设置当前host的ip
export HOSTIP=10.141.59.115
 
# 启动etcd `k-v`服务器
docker run -d -v /etc/ssl/certs:/etc/ssl/certs -p 4001:4001 -p 2380:2380 -p 2379:2379    --name etcd ystyle/etcd  -name etcd0  -advertise-client-urls http://${HOSTIP}:2379,http://${HOSTIP}:4001  -listen-client-urls http://0.0.0.0:2379,http://0.0.0.0:4001  -initial-advertise-peer-urls http://${HOSTIP}:2380  -listen-peer-urls http://0.0.0.0:2380  -initial-cluster-token etcd-cluster-1  -initial-cluster etcd0=http://${HOSTIP}:2380  -initial-cluster-state new
加入集群


在centos-node1执行:
Shell
docker run -d swarm join --addr=10.141.59.115:2375 etcd://10.141.59.115:2379/swarm
在centos-node2执行:
Shell
docker run -d swarm join --addr=10.141.60.136:2375 etcd://10.141.59.115:2379/swarm
在centos-node3执行:
Shell
docker run -d swarm join --addr=10.141.37.71:2375 etcd://10.141.59.115:2379/swarm
启动swarm manage


在centos-node2上执行


Shell


# 启动swarm manage
docker run -d -p 3376:3376 -t    swarm manage -H 0.0.0.0:3376 etcd://10.141.59.115:2379/swarm


# 检查swarm节点列表
docker run --rm swarm list etcd://10.141.59.115:2379/swarm


# 查看swarm集群信息
# export DOCKER_HOST=10.141.60.136:3376  
docker info


# 测试
docker run --rm -p 8080:80 nginx:alpine  
docker ps -a # 查看nginx安装到哪台机器上了


curl -L http://nginx_host:8080


记录


如果docker info 出现Error: ID duplicated.删掉/etc/docker/key.json文件(我的虚拟机是直接复制出来的)
参考资料


https://docs.docker.com/v1.5/swarm/discovery/#using-etcd
https://docs.docker.com/engine/userguide/networking/get-started-overlay/
https://github.com/docker/swarm
https://github.com/coreos/etcd
https://docs.docker.com/engine/installation/linux/centos/

来自:http://blog.jobbole.com/98873/

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值