Docker Swarm 实践指南

阅读时长 10 分钟读完

Docker Swarm 是 Docker 官方提供的容器编排工具,它可以让我们轻松管理多个 Docker 容器,实现高可用、负载均衡、自动扩缩容等功能。本文将介绍 Docker Swarm 的基本概念和使用方法,并提供实践指南,帮助读者快速上手。

Docker Swarm 概念

Docker Swarm 由一组 Docker 主机组成,其中一个主机为 Swarm Manager,其他主机为 Swarm Node。Swarm Manager 负责管理整个 Swarm 集群,包括容器部署、服务发现、负载均衡等。Swarm Node 则负责运行容器,接受 Swarm Manager 的指令。

Docker Swarm 中的基本概念如下:

  • Service(服务):定义了一个可扩展的应用程序,由多个容器组成。Swarm Manager 会根据 Service 的定义,在 Swarm Node 上启动容器,并进行负载均衡。

  • Task(任务):Service 中每个容器的运行实例称为 Task。Swarm Manager 会根据 Service 的定义,决定在哪些 Swarm Node 上启动 Task,并监控 Task 的健康状态。

  • Node(节点):Swarm 集群中的 Docker 主机称为 Node。Node 可以是 Swarm Manager 或 Swarm Node。

  • Overlay Network(覆盖网络):Swarm 集群内的容器需要进行通信,Overlay Network 提供了跨主机的虚拟网络环境,容器可以通过 Overlay Network 进行通信。

Docker Swarm 使用

准备工作

在使用 Docker Swarm 之前,需要准备一组 Docker 主机。这些主机可以是物理机、虚拟机或云主机,需要安装 Docker,并在同一网络环境下。

其中一个主机将作为 Swarm Manager,其他主机将作为 Swarm Node。在 Swarm Manager 上执行以下命令,初始化 Swarm 集群:

执行成功后,会输出一个加入 Swarm 集群的命令,例如:

将输出的命令复制到其他主机上执行,即可将其加入到 Swarm 集群中。

创建 Service

在 Swarm Manager 上执行以下命令,创建一个 Service:

该命令创建了一个名为 web 的 Service,该 Service 包含 3 个 Task,每个 Task 运行一个 nginx 容器。-p 80:80 参数指定了容器端口和主机端口的映射关系。

执行以下命令,查看 Service 运行情况:

执行以下命令,查看 Task 运行情况:

扩缩容 Service

在 Swarm Manager 上执行以下命令,将 Service 的 Task 数量扩展到 5:

执行以下命令,查看 Task 运行情况:

在 Swarm Manager 上执行以下命令,将 Service 的 Task 数量缩减到 2:

执行以下命令,查看 Task 运行情况:

更新 Service

在 Swarm Manager 上执行以下命令,修改 Service 的镜像为 nginx:alpine:

该命令会更新 Service 的镜像,并重启所有 Task。执行以下命令,查看更新后的镜像:

删除 Service

在 Swarm Manager 上执行以下命令,删除 Service:

该命令会删除 Service,并停止所有 Task。

实践指南

使用 Docker Compose 部署服务

Docker Compose 是 Docker 官方提供的工具,可以通过编写 YAML 文件,定义多个容器的部署方式。在 Swarm 集群中,可以通过 Docker Compose 部署 Service,简化部署流程。

例如,以下是一个部署 WordPress 应用程序的 Docker Compose 文件:

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

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

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

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

该文件定义了两个 Service:db 和 wordpress。db Service 运行一个 MySQL 容器,wordpress Service 运行一个 WordPress 容器。两个 Service 通过 Overlay Network 进行通信。

在 Swarm Manager 上执行以下命令,部署该应用程序:

该命令会创建一个名为 wordpress 的 Stack,包含两个 Service:db 和 wordpress。执行以下命令,查看 Stack 运行情况:

执行以下命令,查看 Service 运行情况:

使用 Swarm Visualizer 监控集群状态

Swarm Visualizer 是一个开源的 Docker 容器,可以可视化显示 Swarm 集群的状态。使用 Swarm Visualizer 可以方便地监控集群状态和容器运行情况。

在 Swarm Manager 上执行以下命令,启动 Swarm Visualizer 容器:

该命令会启动 Swarm Visualizer 容器,并将容器端口 8080 映射到主机端口 8080。执行以下命令,访问 Swarm Visualizer:

在 Swarm Visualizer 中,可以查看 Swarm 集群的状态和容器运行情况。

总结

Docker Swarm 是一个强大的容器编排工具,可以方便地管理多个 Docker 容器,实现高可用、负载均衡、自动扩缩容等功能。本文介绍了 Docker Swarm 的基本概念和使用方法,并提供了实践指南,帮助读者快速上手。使用 Docker Swarm 可以大大简化容器部署和管理的工作,提高工作效率。

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/65871254d2f5e1655d153f06

纠错
反馈