前言

朋友的杜甫玩pve,送了我一台小鸡,配置还挺高,装个docker swarm。

Docker Swarm 是什么?

Docker Swarm 是Docker官方的跨节点的容器编排工具。用户只需要在单一的管理节点上操作,即可管理集群下的所有节点和容器。

与k8s同为容器集群管理系统(容器编排工具),学会swarm后更好理解k8s。简而言之,swarm 就是管理多个docker容器(多个机器)的管理工具,它能轻松实现服务的分布式部署、高可用、负载均衡。


一、安装docker

curl -fsSL https://get.docker.com/ | sh

二、修改主机名

修改主机名,更改成swarm01,swarm02,这样更好的管理、查看集群

hostnamectl set-hostname swarm01

三、初始化Swarm

docker swarm init --advertise-addr  172.17.30.109

Swarm initialized: current node (ld1dpbt6rrkpx2jnriqqzow21) is now a manager.

To add a worker to this swarm, run the following command:

    docker swarm join \
    --token SWMTKN-1-3ktv788059o9gl65styt1g3p2twtyho0xzito0082viekstpi7-6qclsdoo2qw67iq7jyud3qv65 \
    172.17.30.109:2377

To add a manager to this swarm, run 'docker swarm join-token manager' and follow the instructions.


四、查看集群节点

docker node list
ID                            HOSTNAME            STATUS              AVAILABILITY        MANAGER STATUS      ENGINE VERSION
j52o5frhmphiksqz0xq1mkbbh *   node1               Ready               Active              Leader              18.09.7
nq6v8dog0xzgpzx51x7bv59bp     node2               Ready               Active                                  18.09.7
6whtoqrhkzv3ax4xy9ab20gmy     node3               Ready               Active                                  18.09.7

五、其他机器加入集群

1.分别在各个机器安装docker
2.加入swarm集群,直接复制初始化swarm后的命令,在工作节点中执行
    docker swarm join \
    --token SWMTKN-1-3ktv788059o9gl65styt1g3p2twtyho0xzito0082viekstpi7-6qclsdoo2qw67iq7jyud3qv65 \
    172.17.30.109:2377

六、Docker Stack 部署集群应用

单机模式下,可以使用 Docker Compose 来编排多个服务。Docker Compose只能实现对单个机器的简单部署。而Docker Stack 只需对已有的 docker-compose.yml 配置文件稍加改造就可以完成 Docker 集群环境下的多服务编排。

# 创建nginx、ftp目录及配置文件
mkdir -p /home/nginxconf
mkdir -p /home/html
mkdir -p /home/nginx
mkdir -p /home/ftp/etc
cd  /home/nginxconf
touch default.conf
#创建compose文件
vi swarm-compose.yml
#mode 分两种情况replicated和global
# replicated:复制服务,复制指定服务到集群的机器上。这种情况支持replicas
#global:全局服务,服务将部署至集群的每个节点。

version: "3"
services:
  nginx-master:
    image: nginx     # 镜像名称
    restart: always     # 开机自动重启
    ports: # 端口号绑定(宿主机:容器内)
      - 80:80
    volumes: # 目录映射(宿主机:容器内)/etc/nginx/conf.d/default.conf
      - /home/nginxconf/default.conf:/etc/nginx/conf.d/default.conf
      - /home/html:/usr/share/nginx/html
      - /home/nginx:/cdn/upload #配置容器内部cdn目录映射到主机的/home/nginx目录,nginx代理配置了内部/cdn/upload
      - /etc/localtime:/etc/localtime:ro #容器内的时间与宿主机一致
    deploy:
      mode: global #在集群中每个节点都安装一个容器
      restart_policy:
        condition: on-failure
    networks:
      - mgb
  ftp-master:
    image: stilliard/pure-ftpd
    volumes:
      - /home/ftp:/home/ftpusers/www
      - /home/ftp/etc:/etc/pure-ftpd/passwd
    ports:
      - "20-21:20-21"
      - "30000-30009:30000-30009"
    command:
      /bin/sh -c "/run.sh -c 100 -C 100 -l puredb:/etc/pure-ftpd/pureftpd.pdb -E -j -R -P 47.115.15.140  -p 30000:30009"
    deploy:
      replicas: 1
      restart_policy:
        condition: on-failure
      placement:
        constraints: #添加条件约束(只在某个节点中运行)
          - node.id == ff7temvlhhi44u5orato6mhp0
    networks:
      - mgb

networks:
  mgb:
    driver: overlay

与单个docker容器部署不同,warm是用stack deploy 命令部署:

docker stack deploy -c swarm-compose.yml --with-registry-auth box

以上命令为部署一个新的stack(堆栈)或更新现有的stack。别名:box。


以上就是docker 集群部署应用的全部内容了,下面为常用命令


七、查看加入节点token

warm join-token :可以查看或更换join token。
docker swarm join-token worker:查看加入woker的命令。
docker swarm join-token manager:查看加入manager的命令
docker swarm join-token --rotate worker:重置woker的Token。
docker swarm join-token -q worker:仅打印Token。

八、 node管理

# 让 node3 离开,排空 node3 的容器(在 master 上操作)
docker node update --availability drain 6whtoqrhkzv3ax4xy9ab20gmy

# 让 node3 主动离开集群,让节点处于down状态 (在 node3 上操作)
docker swarm leave

# 删除 node节点(在 master 上操作)
docker node rm 6whtoqrhkzv3ax4xy9ab20gmy

# 让 node3 离开,排空 node3 的容器(在 master 上操作)
docker node update --availability drain 6whtoqrhkzv3ax4xy9ab20gmy

九、label 管理

在管理者上操作
#########注意##########
如果compose文件指定了role运行条件服务器必须指定role,否则执行compose文件不会运行镜像
#########注意##########
添加标签
docker node update --label-add role=api-server swarm01
查看标签
docker node inspect swarm01
删除标签
docker node update --label-rm role swarm01

十、一些命令

#查看redis容器分布的节点
docker service ps redis

#清空node1节点的任务
docker node update --availability drain node1 


#查看此时任务分配的节点
docker service ps redis

#检查节点的可用性
docker node inspect --pretty node1

#启用被清空的节点
docker node update --availability active node1

当节点的状态变为Active时,可以接受新的任务

在服务更新期间进行扩展
在滚动更新期间
当您设置另一个节点以耗尽可用性时
当另一个活动节点上的任务失败时