如何部署 Docker Swarm 服务

DockerBeginner
立即练习

简介

本教程将指导你使用 Docker Swarm(一个强大的容器编排工具)来部署和管理应用程序。你将学习如何设置 Docker Swarm 集群、部署服务、对其进行扩展和负载均衡、更新和回滚服务以及保护你的 Docker 环境。在本教程结束时,你将对如何利用 Docker Swarm 简化应用程序部署和管理流程有深入的了解。

Docker Swarm 基础

Docker Swarm 简介

Docker Swarm 是一种用于 Docker 容器的原生集群和编排解决方案。它使开发者能够创建和管理 Docker 节点集群,将多个物理机或虚拟机转变为一个用于容器部署和管理的强大虚拟系统。

Docker Swarm 的关键概念

Docker Swarm 引入了几个用于容器编排的关键概念:

概念 描述
群模式(Swarm Mode) Docker 的原生集群模式
管理节点(Manager Node) 控制和管理群集
工作节点(Worker Node) 执行容器工作负载
服务(Service) 定义要部署的容器化应用程序

架构概述

graph TD
    A[管理节点(Manager Node)] --> B[工作节点 1(Worker Node 1)]
    A --> C[工作节点 2(Worker Node 2)]
    A --> D[工作节点 3(Worker Node 3)]

初始化群集

要启动一个 Docker Swarm 集群,在 Ubuntu 22.04 上使用以下命令:

## 安装 Docker
sudo apt-get update
sudo apt-get install docker.io

## 初始化群模式
docker swarm init

## 检查集群状态
docker info | grep Swarm

节点管理

将节点加入群集需要由管理节点生成的加入令牌:

## 在管理节点上:生成加入令牌

## 在工作节点上:加入群集

服务部署基础

在整个群集中创建并部署一个简单的服务:

## 部署一个有三个副本的 nginx 服务
docker service create --replicas 3 --name web nginx

此命令会在群集上创建三个相同的 nginx 容器实例,展示了 Docker Swarm 的核心容器编排功能。

集群配置

群集初始化策略

Docker Swarm 集群配置涉及战略性的节点管理和精确的网络配置。初始化过程决定了集群的基本架构和通信协议。

节点角色与配置

graph TD
    A[管理节点(Manager Node)] -->|控制(Controls)| B[工作节点(Worker Nodes)]
    A -->|管理(Manages)| C[服务部署(Service Deployment)]
    A -->|监控(Monitors)| D[集群健康(Cluster Health)]
节点类型 职责 推荐数量
管理节点(Manager Nodes) 集群管理、编排 3 - 5 个节点
工作节点(Worker Nodes) 容器执行 可扩展

网络配置命令

使用特定的 IP 和接口配置 Docker Swarm 网络:

## 为群集指定网络接口
docker swarm init --advertise-addr eth0:2377

## 查看当前网络配置
docker info | grep -A 5 Swarm

高级节点配置

添加具有特定标签和约束的节点:

## 添加带有自定义标签的节点
docker node update --label-add type=backend node1

## 将服务部署到特定节点类型
docker service create --constraint node.labels.type==backend nginx

安全与认证

安全地管理节点加入令牌:

## 重新生成工作节点加入令牌
docker swarm join-token worker -q

## 轮换管理节点加入令牌
docker swarm join-token manager -q

服务部署

服务创建基础

Docker Swarm 服务代表了应用程序部署的核心单元,能够在整个集群中实现分布式容器管理。

graph LR
    A[Docker 服务(Docker Service)] --> B[容器副本(Container Replicas)]
    A --> C[负载均衡(Load Balancing)]
    A --> D[滚动更新(Rolling Updates)]

基本服务部署策略

部署类型 描述 命令示例
复制模式(Replicated Mode) 固定数量的容器 docker service create --replicas 3
全局模式(Global Mode) 每个节点一个容器 docker service create --mode global

服务创建示例

使用特定配置部署一个 Web 应用程序:

## 使用自定义设置创建一个 Web 服务
docker service create \
  --name webapp \
  --replicas 5 \
  --publish 8080:80 \
  --update-parallelism 2 \
  --update-delay 10s \
  nginx:latest

高级服务管理

动态扩展和更新服务:

## 扩展服务实例
docker service scale webapp=10

## 执行滚动更新
docker service update \
  --image nginx:latest \
  --update-parallelism 2 \
  --update-delay 10s \
  webapp

服务约束与放置

使用节点约束配置服务部署:

## 在特定节点类型上部署服务
docker service create \
  --constraint node.labels.type==web \
  --name frontend \
  nginx:alpine

总结

这本关于“使用 Docker Swarm 部署和管理应用程序”的全面教程,为你提供了有效利用 Docker Swarm 满足应用程序部署和管理需求所需的知识和技能。你已经学习了如何设置 Docker Swarm 集群、部署服务、对其进行扩展和负载均衡、更新和回滚服务以及保护你的 Docker 环境。有了这些技能,你现在可以自信地使用 Docker Swarm 强大的容器编排功能来管理你的应用程序了。