Swarm创建docker集群:服务发现-etcd
2016-01-19 13:12
941 查看
不详细介绍swarm、docker的原理、架构
通过Docker + Etcd + Swarm 搭建docker集群
docker节点(docker node):docker的运行环境,通常为物理机或者虚拟机
其中
该步骤是启动了etcd,并在4001端口监听,以便各个docker节点进行上报。
将[swarm_manager_port]替换成自己环境中可用的端口,比如2376
将[etcd_ip]换成etcd所在环境的ip,例如docker集群master节点的ip(etcd运行的位置决定了该ip的值)
将[etcd_port]换成启动etcd时映射到host机后的端口,比如4001
将
将
将[etcd_ip]换成etcd所在环境的ip,例如docker集群master节点的ip(etcd运行的位置决定了该ip的值)
将[etcd_port]换成启动etcd时映射到host机后的端口,比如4001
将swarm_ip换成swarm所在的节点的ip。
将swarm_manager_port换成swarm的端口,例如2376.
可以看到如下内容:
通过
通过
通过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已经实验完成
相关文章推荐
- docker容器的网络信息查看
- RedHat 5.8 安装Oracle 11gR2_Grid集群
- mysql集群之MMM简单搭建
- 在windows下的安装Docker的教程
- 8个你可能不知道的Docker知识
- MySQL的集群配置的基本命令使用及一次操作过程实录
- MySQL slave_net_timeout参数解决的一个集群问题案例
- Redis 集群搭建和简单使用教程
- Windows Server 2003 下配置 MySQL 集群(Cluster)教程
- 在Docker中自动化部署Ruby on Rails的教程
- tomcat6_apache2.2_ajp 负载均衡加集群实战分享
- 搭建基于Docker的PHP开发环境的详细教程
- 利用OpenVSwitch在多台主机上部署Docker的教程
- ubuntu14.04+docker的安装及使用
- Docker 清理命令集锦
- 再Docker中架设完整的WordPress站点全攻略
- 基于 Docker 开发 NodeJS 应用
- 使用Docker来加速构建Android应用的基本部署思路解析
- 用apache和tomcat搭建集群(负载均衡)