Docker Swarm Mode 学习笔记(聊聊 replicas)

在 Swarm 集群中, 创建服务时可以通过设置 --replicas 参数来指定此服务在工作节点上运行的任务数。

示例

这里我们来创建一个 nginx 服务作为示例:

version: '3'

services: 
  nginx:
    image: nginx:latest
    deploy:
      replicas: 3
    ports: 
      - "80:80"
    networks: 
      - net
  visualizer:
    image: dockersamples/visualizer:stable
    ports: 
      - "8080:8080"
    volumes: 
      - "/var/run/docker.sock:/var/run/docker.sock"
    deploy:
      placement:
        constraints: [node.role == manager]
    networks: 
      - net

networks: 
  net:

在文件所在目录执行 docker stack deploy -c docker-compose.yml nginx 来创建服务,由于我这里只准备了一台 Docker 主机, 所以在这个 Swarm 集群中情况如图所示:

Docker Swarm Mode 学习笔记(聊聊 replicas)

可以看到我们的 nginx 服务创建了 3个 nginx_nginx 任务, 1个visualizer 服务。

docker ps 查看所有容器

docker exec -it <container id> /bin/bash 依次进入到3个 nginx_nginx 任务所对应的容器中

cd /usr/share/nginx/html 找到 index.html 文件

将3个容器中 index.html 的内容分别改为 nginx.1, nginx.2, nginx.3

echo nginx.1 > index.html

...

然后我们访问 http://127.0.0.1 , 即可看到相对应的修改页面。 这里我们多尝试几次,会发现,有时候出现的是 nginx.1, 也会出现 nginx.2, nginx.3 。 这就是 Docker Swarm 集群模式中自带的负载均衡带来的效果。

下面,我们来收缩或者拓展在一台工作节点上执行的任务量:

收缩:

docker service scale nginx_nginx=2

拓展

docker service scale nginx_nginx=5

可通过 docker service ls 来查看服务概况。

总结

服务的部署模式有两种:

  • global : 每个工作节点上都会运行一个服务
  • replicated: 每个工作节点会运行 replicas 个服务

Docker Swarm 集群内置的负载均衡,在同一个工作节点上, 多个相同的任务(容器)会由 Swarm 集群的负载均衡来命中。

上一篇:对比剖析Swarm Kubernetes Marathon编排引擎


下一篇:Docker Swarm Mode 学习笔记 (部署服务)