阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

如何配置一个 Docker Swarm 原生集群

260次阅读
没有评论

共计 2933 个字符,预计需要花费 8 分钟才能阅读完成。

嗨,大家好。今天我们来学一学 Swarm 相关的内容吧,我们将学习通过 Swarm 来创建 Docker 原生集群。Docker Swarm 是用于 Docker 的原生集群项目,它可以将一个 Docker 主机池转换成单个的虚拟主机。Swarm 工作于标准的 Docker API,所以任何可以和 Docker 守护进程通信的工具都可以使用 Swarm 来透明地伸缩到多个主机上。就像其它 Docker 项目一样,Swarm 遵循“内置电池,并可拆卸”的原则(LCTT 译注:batteries included,内置电池原来是 Python 圈里面对 Python 的一种赞誉,指自给自足,无需外求的丰富环境;but removable,并可拆卸应该指的是非强制耦合)。它附带有一个开箱即用的简单的后端调度程序,而且作为初始开发套件,也为其开发了一个可插拔不同后端的 API。其目标在于为一些简单的使用情况提供一个平滑的、开箱即用的体验,并且它允许切换为更强大的后端,如 Mesos,以用于大规模生产环境部署。Swarm 配置和使用极其简单。

如何配置一个 Docker Swarm 原生集群

这里给大家提供 Swarm 0.2 开箱的即用一些特性。

  1. Swarm 0.2.0 大约 85% 与 Docker 引擎兼容。
  2. 它支持资源管理。
  3. 它具有一些带有限制和类同功能的高级调度特性。
  4. 它支持多个发现后端(hubs,consul,etcd,zookeeper)
  5. 它使用 TLS 加密方法进行安全通信和验证。

那么,我们来看一看 Swarm 的一些相当简单而简用的使用步骤吧。

 

1. 运行 Swarm 的先决条件

我们必须在所有节点安装 Docker 1.4.0 或更高版本。虽然各个节点的 IP 地址不需要要公共地址,但是 Swarm 管理器必须可以通过网络访问各个节点。

注意:Swarm 当前还处于 beta 版本,因此功能特性等还有可能发生改变,我们不推荐你在生产环境中使用。

 

2. 创建 Swarm 集群

现在,我们将通过运行下面的命令来创建 Swarm 集群。各个节点都将运行一个 swarm 节点代理,该代理会注册、监控相关的 Docker 守护进程,并更新发现后端获取的节点状态。下面的命令会返回一个唯一的集群 ID 标记,在启动节点上的 Swarm 代理时会用到它。

在集群管理器上运行:

  1. # docker run swarm create

如何配置一个 Docker Swarm 原生集群

Creating Swarm Cluster

 

3. 启动各个节点上的 Docker 守护进程

我们需要登录进我们将用来创建集群的每个节点,并在其上使用 - H 标记启动 Docker 守护进程。它会保证 Swarm 管理器能够通过 TCP 访问到各个节点上的 Docker 远程 API。要启动 Docker 守护进程,我们需要在各个节点内部运行以下命令。

  1. # docker -H tcp://0.0.0.0:2375 -d

如何配置一个 Docker Swarm 原生集群

Starting Docker Daemon

 

4. 添加节点

在启用 Docker 守护进程后,我们需要添加 Swarm 节点到发现服务,我们必须确保节点 IP 可从 Swarm 管理器访问到。要完成该操作,我们需要在各个节点上运行以下命令。

  1. # docker run -d swarm join --addr=<node_ip>:2375 token://<cluster_id>

如何配置一个 Docker Swarm 原生集群

Adding Nodes to Cluster

注意 :我们需要用步骤 2 中获取到的节点 IP 地址和集群 ID 替换这里的 <node_ip> 和 <cluster_id>。

 

5. 开启 Swarm 管理器

现在,由于我们已经获得了连接到集群的节点,我们将启动 swarm 管理器。我们需要在集群管理器中运行以下命令。

  1. # docker run -d -p <swarm_port>:2375 swarm manage token://<cluster_id>

如何配置一个 Docker Swarm 原生集群

Starting Swarm Manager

 

6. 检查配置

一旦管理运行起来后,我们可以通过运行以下命令来检查配置。

  1. # docker -H tcp://<manager_ip:manager_port> info

如何配置一个 Docker Swarm 原生集群

Accessing Swarm Clusters

注意 :我们需要替换 <manager_ip:manager_port> 为运行 swarm 管理器的主机的 IP 地址和端口。

 

7. 使用 docker CLI 来访问节点

在一切都像上面说得那样完美地完成后,这一部分是 Docker Swarm 最为重要的部分。我们可以使用 Docker CLI 来访问节点,并在节点上运行容器。

  1. # docker -H tcp://<manager_ip:manager_port> info
  2. # docker -H tcp://<manager_ip:manager_port> run ...

 

8. 监听集群中的节点

我们可以使用 swarm list 命令来获取所有运行中节点的列表。

  1. # docker run --rm swarm list token://<cluster_id>

如何配置一个 Docker Swarm 原生集群

Listing Swarm Nodes

 

尾声

Swarm 真的是一个有着相当不错的功能的 docker,它可以用于创建和管理集群。它相当易于配置和使用,当我们在它上面使用限制器和类同器时它更为出色。高级调度程序是一个相当不错的特性,它可以应用过滤器来通过端口、标签、健康状况来排除节点,并且它使用策略来挑选最佳节点。那么,如果你有任何问题、评论、反馈,请在下面的评论框中写出来吧,好让我们知道哪些材料需要补充或改进。谢谢大家了!尽情享受吧 :-)

Ubuntu 15.04 下安装 Docker  http://www.linuxidc.com/Linux/2015-07/120444.htm

配置 Docker 镜像下载的本地 mirror 服务  http://www.linuxidc.com/Linux/2015-07/120061.htm

Docker 安装应用 (CentOS 6.5_x64) http://www.linuxidc.com/Linux/2014-07/104595.htm 

在 Docker 中使用 MySQL http://www.linuxidc.com/Linux/2014-01/95354.htm

在 Ubuntu Trusty 14.04 (LTS) (64-bit) 安装 Docker http://www.linuxidc.com/Linux/2014-10/108184.htm 

Docker 安装应用 (CentOS 6.5_x64) http://www.linuxidc.com/Linux/2014-07/104595.htm 

Ubuntu 14.04 安装 Docker  http://www.linuxidc.com/linux/2014-08/105656.htm 

阿里云 CentOS 6.5 模板上安装 Docker http://www.linuxidc.com/Linux/2014-11/109107.htm 

Docker 的详细介绍 :请点这里
Docker 的下载地址 :请点这里


via: http://linoxide.com/linux-how-to/configure-swarm-clustering-docker/

作者:Arun Pyasi 译者:GOLinux 校对:wxy

本文由 LCTT 原创翻译,Linux 中国 荣誉推出

本文永久更新链接地址 :http://www.linuxidc.com/Linux/2015-07/120760.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-20发表,共计2933字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中