设为首页 收藏本站
查看: 1746|回复: 0

[经验分享] Swarm创建docker集群:服务发现-etcd

[复制链接]

尚未签到

发表于 2019-1-31 12:42:52 | 显示全部楼层 |阅读模式
  术语
  本文中用到的术语书名
  docker节点(docker node):docker的运行环境,通常为物理机或者虚拟机
  测试环境
  2个docker主机的配置如下所示
  [root@localhost ~]# cat /etc/redhat-release

  CentOS Linux>  [root@localhost ~]# docker --version
  Docker version 1.8.2-el7.centos, build a01dc02/1.8.2
  [root@localhost ~]#
  1
  2
  3
  4
  5
  配置docker
  主要是配置docker的api端口,具体参考docker的安装&配置
  准备Docker镜像
  docker pull swarm
  docker pull etcd
  1
  2
  启动服务发现:etcd
  在docker集群的master节点上执行下面命令(其实可以在任何一个docker环境中执行下面的命令,只要注意后面使用etcd时的ip即可,将其假设为[etcd_ip])
  docker run -ti -d -p [etcd_port]:4001 --name etcd docker.io/microbox/etcd -name discovery
  1
  其中[map_port]需要替换成自己环境中可用的端口,比如4001。
  该步骤是启动了etcd,并在4001端口监听,以便各个docker节点进行上报。
  启动swarm manger
  docker run -ti -d -p [swarm_manager_port]:2375 --name swarm-manager docker.io/swarm manage etcd://[etcd_ip]:[etcd_port]
  1
  将[swarm_manager_port]替换成自己环境中可用的端口,比如2376
  将[etcd_ip]换成etcd所在环境的ip,例如docker集群master节点的ip(etcd运行的位置决定了该ip的值)
  将[etcd_port]换成启动etcd时映射到host机后的端口,比如4001
  docker节点加入集群
  在每个要加入集群docker节点上执行下面的命令。
  docker run -ti -d --name swarm-agent docker.io/swarm join --addr [docker_node_ip]:[docker_port] etcd://[etcd_ip]:[etcd_port]
  1
  2
  将[docker_node_ip]替换成当前docker节点的ip
  将docker_port替换成当前docker监听的端口,比如2375。端口的配置在本文上面已经介绍,或者参考具体参考docker的安装&配置
  将[etcd_ip]换成etcd所在环境的ip,例如docker集群master节点的ip(etcd运行的位置决定了该ip的值)
  将[etcd_port]换成启动etcd时映射到host机后的端口,比如4001
  验证
  docker -H [swarm_ip]:[swarm_manager_port] info
  1
  将swarm_ip换成swarm所在的节点的ip。
  将swarm_manager_port换成swarm的端口,例如2376.
  可以看到如下内容:
  Containers: 7
  Images: 26
  Role: primary
  Strategy: spread
  Filters: health, port, dependency, affinity, constraint
  Nodes: 2
  ftd.master: [docker_node_ip_1]:2375
  └ Status: Healthy
  └ Containers: 4
  └ Reserved CPUs: 0 / 8
  └ Reserved Memory: 0 B / 32.79 GiB
  └ Labels: executiondriver=native-0.2, kernelversion=3.10.0-229.el7.x86_64, operatingsystem=CentOS Linux 7 (Core), storagedriver=devicemapper
  localhost.localdomain: [docker_node_ip_2]:2375
  └ Status: Healthy
  └ Containers: 3
  └ Reserved CPUs: 0 / 4
  └ Reserved Memory: 0 B / 3.888 GiB
  └ Labels: executiondriver=native-0.2, kernelversion=3.10.0-229.el7.x86_64, operatingsystem=CentOS Linux 7 (Core), storagedriver=devicemapper
  CPUs: 12
  Total Memory: 36.67 GiB
  Name: xxxxxxxxxx
  1
  2
  3
  4
  5
  6
  7
  8
  9
  10
  11
  12
  13
  14
  15
  16
  17
  18
  19
  20
  21
  22
  集群中创建容器
  创建两个容器:执行2次docker run busybox。
  通过docker -H [swarm_ip]:[swarm_port] ps -a可以看到swarm中创建的docker容器.
  通过docker ps -a可以看到2个容器分布在不同的docker节点。
  至此,Docker + Etcd + Swarm已经实验完成


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-670060-1-1.html 上篇帖子: Etcd v3.3.10 版本部署(3台集群) 下篇帖子: 没有了
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表