我是靠谱客的博主 可靠热狗,最近开发中收集的这篇文章主要介绍Swarm创建docker集群:服务发现-etcd,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

  • 不详细介绍swarm、docker的原理、架构
  • 通过Docker + Etcd + Swarm 搭建docker集群

术语

本文中用到的术语书名

docker节点(docker node):docker的运行环境,通常为物理机或者虚拟机

测试环境

  • 2个docker主机的配置如下所示
[root@localhost ~]# cat /etc/redhat-release
CentOS Linux release 7.1.1503 (Core)
[root@localhost ~]# docker --version
Docker version 1.8.2-el7.centos, build a01dc02/1.8.2
[root@localhost ~]#

配置docker

主要是配置docker的api端口,具体参考docker的安装&配置

准备Docker镜像

docker pull swarm
docker pull etcd

启动服务发现:etcd

在docker集群的master节点上执行下面命令(其实可以在任何一个docker环境中执行下面的命令,只要注意后面使用etcd时的ip即可,将其假设为[etcd_ip])

docker run -ti -d -p [etcd_port]:4001 --name etcd docker.io/microbox/etcd -name discovery

其中[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]
  • 将[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]
  • [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
  • 将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

集群中创建容器

创建两个容器:执行2次docker run busybox
通过docker -H [swarm_ip]:[swarm_port] ps -a可以看到swarm中创建的docker容器.
通过docker ps -a可以看到2个容器分布在不同的docker节点。

至此,Docker + Etcd + Swarm已经实验完成

最后

以上就是可靠热狗为你收集整理的Swarm创建docker集群:服务发现-etcd的全部内容,希望文章能够帮你解决Swarm创建docker集群:服务发现-etcd所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(49)

评论列表共有 0 条评论

立即
投稿
返回
顶部