Docker Swarm 入门教程

什么是 Docker Swarm?

Docker Swarm 是 Docker 官方提供的一个容器编排工具,它可以让您轻松地管理多个 Docker 容器,实现容器的自动化部署、伸缩和高可用等功能,是构建分布式应用的理想选择。

安装 Docker Swarm

在使用 Docker Swarm 之前,您需要先安装 Docker 环境。如果您还没有安装 Docker,可以参考官方文档进行安装。

安装完成后,您需要启用 Docker Swarm 模式。在 Docker 17.12 及以上版本中,Swarm 模式已经默认启用,如果您使用的是旧版本的 Docker,可以通过以下命令启用 Swarm 模式:

- ------ ----- ----

创建 Docker Swarm 集群

要创建一个 Docker Swarm 集群,您需要至少两个节点。一个节点可以是 Docker 主机、虚拟机或云服务器。在本教程中,我们将使用两台虚拟机来创建 Swarm 集群。

步骤一:创建虚拟机

我们将使用 VirtualBox 和 Vagrant 来创建两台虚拟机。在安装 VirtualBox 和 Vagrant 后,您可以通过以下命令创建虚拟机:

- ------- ---- ---------------
- ------- --

这将会创建一个基于 Ubuntu 16.04 的虚拟机。

步骤二:加入集群

在第一台虚拟机上执行以下命令,将其加入到 Swarm 集群中:

- ------ ----- ---- ---------------- -------- -- ---

执行成功后,您将获得一条 Token,类似于:

----- ------------ ------- ---- ------ -- --- - --------

-- --- - ------ -- ---- ------ --- --- --------- --------

    ------ ----- ---- ------- ----- -------- -- --------

-- --- - ------- -- ---- ------ --- ------- ----- ---------- -------- --- ------ --- -------------

将这条 Token 复制下来,我们将在第二台虚拟机上使用它来加入到集群中。

在第二台虚拟机上执行以下命令,将其加入到 Swarm 集群中:

- ------ ----- ---- ------- ------- -------- -- --------

执行成功后,您可以在第一台虚拟机上执行以下命令,查看 Swarm 集群的状态:

- ------ ---- --

您将看到两个节点,其中一个是 Manager 节点,另一个是 Worker 节点。

部署应用程序

现在,我们已经成功创建了一个 Swarm 集群,下面我们将在集群中部署一个简单的应用程序。

步骤一:创建服务

我们将使用一个简单的 Node.js 应用程序作为示例。在第一台虚拟机上创建一个文件夹,将以下代码保存为 app.js:

----- ---- - ----------------

----- ------ - ----------------------- ---- -- -
  -------------------
  -------------- ---------
---

------------------- -- -- -
  ------------------- ------- -- ---- -------
---

在该文件夹中创建一个 Dockerfile,内容如下:

---- -------

------- ----

---- ------------- --

--- --- -------

---- - -

------ ----

--- - ------ ------- -

接下来,使用以下命令将应用程序构建为 Docker 镜像:

- ------ ----- -- ----- -

这将创建一个名为 myapp 的 Docker 镜像。

接下来,我们将使用 Docker Swarm 部署该应用程序。在第一台虚拟机上执行以下命令:

- ------ ------- ------ ------ ----- ---------- - -- --------- -----

这将创建一个名为 myapp 的服务,该服务将在 Swarm 集群中创建 3 个副本,并将容器的 3000 端口映射到主机的 3000 端口上。

您可以使用以下命令查看服务的状态:

- ------ ------- --

步骤二:测试应用程序

现在,我们已经成功部署了应用程序,可以使用以下命令测试它:

- ---- -------- -- --------

您将看到输出 Hello World!,这表明应用程序已经成功运行。

总结

在本教程中,我们介绍了如何使用 Docker Swarm 创建集群,并在集群中部署一个简单的应用程序。Docker Swarm 是一个非常强大的容器编排工具,可以帮助您轻松管理多个 Docker 容器,实现容器的自动化部署、伸缩和高可用等功能。如果您正在构建分布式应用程序,Docker Swarm 是一个非常值得尝试的工具。

来源:JavaScript中文网 ,转载请注明来源 本文地址:https://www.javascriptcn.com/post/662f6827d3423812e4d5d162