Docker Swarm 部署Consul集群

1、部署环境

IPhostname部署实例Node labels
172.16.1.101manager01consul_server1-
172.16.1.102manager02consul_server2-
172.16.1.103manager03consul_server3-
172.16.1.104worker01consul_client-
172.16.1.105worker02consul_client-
172.16.1.106worker03consul_client-

2、给相关Swarm节点添加标签,使consul实例部署到指定服务器节点上

#  在任意一个Manager节点上执行
docker node update --label-add consul.cluster=server1 manager01
docker node update --label-add consul.cluster=server2 manager02
docker node update --label-add consul.cluster=server3 manager03
docker node update --label-add consul.cluster=client worker01
docker node update --label-add consul.cluster=client worker02
docker node update --label-add consul.cluster=client worker03

执行以上命令后,各节点Node labels如下:

IPhostname部署实例Node labels
172.16.1.101manager01consul_server1consul.cluster=server1
172.16.1.102manager02consul_server2consul.cluster=server2
172.16.1.103manager03consul_server3consul.cluster=server3
172.16.1.104worker01consul_clientconsul.cluster=client
172.16.1.105worker02consul_clientconsul.cluster=client
172.16.1.106worker03consul_clientconsul.cluster=client

例:在compose编排脚本的deploy属性中,使用placement属性将consul_client服务指定运行在worker01-03节点上,如下:

deploy:
      placement:
        constraints:
          - node.labels.consul.cluster == client

1、部署架构图

在这里插入图片描述

  1. Consul 的 Client 和 Server 及 Server 和 Server之间通过 overlay网络进行通信;
  2. Consul Server1 通过Ingress模式发布UI服务,端口为8500,这样,可通过swarm集群下任何物理机IP:8500访问该UI服务;
  3. Consul Client 和 App Service 通过host模式进行通信:

即:Consul Client 通过 host模式暴露端口8510,所有App Service 通过访问其容器所在宿主机IP:8510 访问Consul Client,进行服务注册与发现;

3、为consul_servert和consul_client创建数据卷映射目录

# 在三个服务器节点上,分别执行以下命令
mkdir -p /{consul_server,consul_client}/data/

4、部署文件说明

涉及到的部署文件有三个:

  1. 编排脚本:consul-compose.yml

定义了Consul集群相关所有服务

4.1、编排脚本:consul-compose.yml

version: '3.7'

services:
  consul-server1:
    image: consul:1.9.3
    container_name: consul-server1
    volumes:
      - /consul_server/data:/consul/data
    networks:
      - middle
    ports:
      - '8500:8500'
    deploy:
      mode: global
      placement:
        constraints:
          - node.labels.consul.cluster == server1
    command: >
      agent -server -ui
      -node=consul-server1
      -bootstrap-expect=3
      -client=0.0.0.0
      -data-dir=/consul/data
      -datacenter=dc1
      -bind '{{ GetPrivateInterfaces | include "network" "192.168.1.0/24" | attr "address" }}'

  consul-server2:
    image: consul:1.9.3
    container_name: consul-server2
    depends_on:
      - consul-server1
    volumes:
      - /consul_server/data:/consul/data
    networks:
      - consul
    deploy:
      mode: global
      placement:
        constraints:
          - node.labels.consul.cluster == server2
    command: >
      agent -server -ui
      -node=consul-server2
      -bootstrap-expect=3
      -client=0.0.0.0
      -retry-join=consul-server1
      -data-dir=/consul/data
      -datacenter=dc1
      -bind '{{ GetPrivateInterfaces | include "network" "192.168.1.0/24" | attr "address" }}'

  consul-server3:
    image: consul:1.9.3
    container_name: consul-server3
    depends_on:
      - consul-server1
    volumes:
      - /consul_server/data:/consul/data
    networks:
      - middle
    deploy:
      mode: global
      placement:
        constraints:
          - node.labels.consul.cluster == server3
    command: >
      agent -server -ui
      -node=consul-server3
      -bootstrap-expect=3
      -client=0.0.0.0
      -retry-join=consul-server1
      -data-dir=/consul/data
      -datacenter=dc1
      -bind '{{ GetPrivateInterfaces | include "network" "192.168.1.0/24" | attr "address" }}'

  consul-client:
    image: consul:1.9.3
    networks:
      - middle
    depends_on:
      - consul-server1
      - consul-server2
      - consul-server3
    ports:
      - target: 8500
        published: 8510
        protocol: tcp
        mode: host
    volumes:
      - /consul_client/data:/consul/data
      - /var/run/docker.sock:/var/run/docker.sock
      - /usr/bin/docker:/usr/bin/docker
    deploy:
      mode: global
      placement:
        constraints:
          - node.labels.consul.cluster == client
    entrypoint: >
      sh -c "docker-entrypoint.sh agent
      -node=consul_client_`docker info --format {{.Name}}`
      -retry-join=consul-server1
      -retry-join=consul-server2
      -retry-join=consul-server3
      -data-dir=/consul/data
      -datacenter=dc1
      -bind '{{ GetPrivateInterfaces | include \"network\" \"192.168.1.0/24\" | attr \"address\" }}'"

networks:
  middle:
    driver: overlay
    ipam:
      driver: default
      config:
        - subnet: "192.168.1.0/24"

脚本说明:

  1. 多网卡情况下,绑定指定网段的IP
-bind '{{ GetPrivateInterfaces | include "network" "192.168.1.0/24" | attr "address" }}'
  1. 获得宿主机hostname
-node=consul_client_`docker info --format {{.Name}}`

最终结果为:-node=consul_client_worker01
这里使用docker info命令的前提是配置以下两个映射

/var/run/docker.sock:/var/run/docker.sock
/usr/bin/docker:/usr/bin/docker

5、部署

部署compose脚本的方式有两种,分别是:命令行、portainer工具

5.1、通过命令行部署

登录到任意一个Manager节点,将consul-compose.yml文件,放到任意目录,比如放到/usr/local/deploy/consul/目录

cd /usr/local/deploy/consul/
 ls ./
consul-compose.yml

然后执行docker stack deploy 命令

cd /usr/local/deploy/consul/
docker stack deploy -c consul-compose.yml consul

5.2、通过Portainer部署

  1. 点击菜单Stacks,点击按钮Add Stack,在Name输入框输入本Stack的名称,如consul,在Build method选项中选择Web editor,并在Web editor文本域中输入文件consul-compose.yml 的内容;
  2. 点击页面底部的Deploy the stack按钮;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Docker Swarm 是 Docker 官方提供的容器编排工具,可以用于管理多个 Docker 容器的集群。Nginx 是一款高性能的 Web 服务器和反向代理服务器,可以用于部署 Web 应用和负载均衡等场景。在 Docker Swarm 中,可以通过部署多个 Nginx 容器来实现 Nginx 集群部署。 具体步骤如下: 1. 准备 Docker Swarm 环境,包括 Docker Engine 和 Docker Swarm。 2. 创建一个 Docker Swarm 集群,可以使用 docker swarm init 命令初始化一个 Swarm 集群。 3. 创建一个 Nginx 镜像,可以使用 Dockerfile 文件构建一个 Nginx 镜像,或者使用已有的 Nginx 镜像。 4. 创建一个 Docker Stack,可以使用 docker stack deploy 命令创建一个 Stack,其中包含多个 Nginx 服务。 5. 配置 Nginx 服务,可以使用 Docker Compose 文件配置 Nginx 服务,包括端口映射、负载均衡等。 6. 启动 Nginx 服务,可以使用 docker stack deploy 命令启动 Nginx 服务。 7. 验证 Nginx 集群是否正常工作,可以使用 curl 命令访问 Nginx 服务,或者使用浏览器访问 Nginx 服务。 以上就是使用 Docker Swarm 部署 Nginx 集群的基本步骤。 ### 回答2: Docker Swarm是Docker官方推出的一个容器编排工具,可以用于管理多个Docker节点组成的集群,实现容器的自动部署、扩展、升级等功能。Nginx是一款高性能的Web服务器软件,可以用于反向代理、负载均衡、静态文件缓存等应用场景,常用于构建Web服务集群。下面将介绍如何使用Docker Swarm部署Nginx集群。 1. 环境准备 首先需要在多台计算机上安装DockerDocker Swarm,可以参考官方文档进行安装。安装完成后,需要将多台计算机加入到一个Docker Swarm集群中,可以使用Docker Swarm的初始化命令和加入命令完成。在集群中选择一台作为Swarm Manager,其他节点作为Swarm Worker。 2. 创建Docker镜像 在部署Nginx集群之前,需要先创建Nginx的Docker镜像。可以使用Dockerfile构建镜像,或者使用Docker Hub上已有的Nginx镜像。在这里使用已有的Nginx镜像,并根据自己的要求修改Nginx的配置文件。 3. 创建Docker服务 创建Nginx的Docker服务,需要指定镜像名称、服务名称、副本数量、端口映射、挂载目录等参数。在创建服务时可以指定网络,此处需要创建一个Overlay网络,用于集群内部容器间通信。创建完成后,Docker Swarm会自动将服务的副本运行在集群内部的Worker节点上。 4. 部署Nginx集群集群内部创建多个Nginx服务,然后利用Docker Swarm的负载均衡功能将请求分发到不同的Nginx容器上。可以使用nginx.conf文件配置负载均衡策略,例如轮询、IP哈希等。在访问Nginx服务时,只需要访问Swarm Manager节点的VIP地址即可,Swarm会自动将请求分发到不同的Nginx容器上。 总结 Docker Swarm是一个强大的容器编排工具,可以用于管理复杂的容器集群。通过使用Docker Swarm,可以轻松地部署Nginx集群,提高Web服务的可用性和性能,实现高可用、高扩展性的服务架构。 ### 回答3: Docker是现今最为流行的容器化平台,其可以帮助我们将应用程序和其依赖项一起打包在一个可移植容器中。而Docker Swarm是Docker的官方集群管理工具,它允许我们快速轻松地构建、管理和扩展Docker容器集群。下面将介绍如何在Docker Swarm上部署nginx集群。 步骤一:创建Docker Swarm集群 首先,需要在集群中创建几个节点。在某台用作管理节点的机器上运行以下命令,在该机器上创建一个Swarm: ``` docker swarm init ``` 运行上述命令后,系统会返回一个命令,该命令需要您在其他节点上运行以加入集群。 步骤二:建立nginx镜像 接下来,需要创建一个基于Nginx的Docker镜像,并将其上传到Docker Hub。 ``` FROM nginx COPY nginx.conf /etc/nginx/nginx.conf CMD ["nginx", "-g", "daemon off;"] ``` 步骤三:使用docker stack 部署nginx集群 现在,启动一个名为“web”的服务,该服务由两个副本组成,并使用刚刚创建的Nginx镜像。 ``` docker service create -p 8080:80 --name web --replicas 2 nginx ``` 上述命令将在Docker Swarm集群中启动名为“web”的服务。使用标志“-p”将本地端口8080映射到容器的80端口。使用标志“--replicas”指定了启动两个副本。此命令将指定Nginx映像部署到Swarm中。 步骤四:查看nginx集群运行状态 在集群运行过程中,可以使用以下命令查看服务和副本的状态: ``` docker service ls ``` 此外,执行以下命令可以查看服务的状态和详细信息: ``` docker service ps web ``` 此命令将返回当前正在运行的服务副本的详细信息。通过查看这些信息,可以查看每个副本的IP地址和状态。 步骤五:测试nginx集群的负载均衡 现在,该nginx集群已成功部署。您可以使用“curl”命令或浏览器将请求发送到集群的任何成员。每次请求将自动转发到由Swarm管理的每个副本中的一个。 在浏览器中输入http://localhost:8080,您将看到nginx的欢迎页面,并可以看到每个请求都将定向到不同的副本。 总结 在Docker Swarm上部署nginx集群,可以快速轻松地运行一个高可靠性、高可用性的Web应用程序。使用Docker Swarm,我们可以轻松地扩展集群,通过使用负载均衡技术将请求自动转发到不同的副本。同时,Docker Swarm还提供了集群管理的所有功能,包括自动部署、升级和维护等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值