Docker之Docker Swarm调度容器

简介: Docker之Docker Swarm调度容器

之前我们写了好多篇关于docker的文章,但是环境都是单机的,也就是说只有一台docker引擎。

接下来这篇文章我们说一下docker集群及管理。

Docker官方为了解决多容器管理问题,推出了Docker Swarm工具,也是我们今天要说的内容。

Swarm简单介绍:

  • Swarm首个版本在2014年12月初发布,2016年2月对架构进行重新设计,推出V2版本。
  • 支持原生Docker API。
  • 采用主从结构,通过Raft协议在多个管理节点中实现共识。

Swarm架构:

Swarm架构整体分为管理节点(Manager)和工作节点(Worker)

管理节点:响应外部对集群的操作请求,Swarm负责调度和管理容器,分发任务给工作节点。一个集群通常设置3、5、7个管理节点,但是必须为单数。

工作节点:负责执行具体任务。默认情况,管理节点自身也是工作节点。

  • 用户可通过docker node promote将一个节点提升为管理节点;也可以通过docker node demote将一个管理节点降级为工作节点。

Swarm核心概念:

  • 服务(service):服务是为了支持编排所提出的概念,它是一系列复杂容器环境相互协作的统称。一个服务的声明包含容器的启动方式、副本数、环境变量、存储、配置、网络等一系列配置。用户用过Swarm将声明的服务实现。
  服务分为全局服务和副本服务:
  全局服务:每个工作节点都会运行一个任务
  副本服务:按照指定副本数在集群中调度
  • 任务:集群中最小的调度单位,即一个运行的应用容器。
  • 服务外部访问:Swarm中支持入口负载均衡的映射模式。该模式每个服务都会被分配一个公开端口,该端口在集群中任意节点都可以访问到,并被保留给该服务。

搭建Swarm集群:

  • Docker版本大于1.12,推荐最新稳定版
  • 主机需要开放2377、4789、7946端口

原本我应该通过3个管理节点,若干工作节点来搭建集群,但是原谅我的本的性能,所以只能搭建一管理节点二工作节点的集群,但是并不妨碍讲解。

第一步:主备三台装有Docker引擎的主机,这点不说了,Docker搭建可以看我其他文章有这个。

第二步:初始化集群(1.12版本后已经默认集成到Docker中)

  • 在管理节点上,通过以下命令初始化集群
  • 如果多网卡需要加–advertise-addr参数指定网卡
docker swarm init --advertise-addr 192.168.10.3
  • 节点加入集群需要用到以下信息


Swarm initialized: current node (hgya55eyardntljupfmpxsw3s) is now a manager.
To add a worker to this swarm, run the following command:
    docker swarm join --token SWMTKN-1-457a1eursgbfc5m6lnxz224w6izmsdq82cv8rwfnj8ac6eujhb-5ph3idc72q66tpbaaic5bc6k7 192.168.10.3:2377
To add a manager to this swarm, run 'docker swarm join-token manager' and follow the instructions.

a3637adec5904988b777aaae46002478.png

第三步:加入工作节点到集群(两个工作节点都要加入)

docker swarm join --token SWMTKN-1-457a1eursgbfc5m6lnxz224w6izmsdq82cv8rwfnj8ac6eujhb-5ph3idc72q66tpbaaic5bc6k7 192.168.10.3:2377

第四步***:如果加入管理节点到集群(如果你想有多个管理节点看这步,单节点跳过即可)

  • 在管理节点上运行以下命令,然后想成为管理节点的主机上输入显示的结果即可
docker swarm join-token manager


第五步:查看节点

docker node ls
  • 可查看所有节点,带星号为管理节点
ID                            HOSTNAME   STATUS    AVAILABILITY   MANAGER STATUS   ENGINE VERSION
h55mmpjvnd3uh1jrkopuas400     centos7    Ready     Active                          20.10.7
hgya55eyardntljupfmpxsw3s *   centos7    Ready     Active         Leader           20.10.7
y3ymp2sis7xwezzuhyhhy4h64     centos7    Ready     Active                          20.10.7
  • 通过docker info可以查看集群信息,内容太多就不复制了。
  • 如果想看的更明显,可以将主机名改成节点名,我忘了。。。
  • 到此,一个集群算搭建完成。

使用Swarm:

Swarm中部署服务通常用两种方式:

一.通过docker service命令创建

  • 通过docker service命令可以查看命令用法:
docker service 
Usage:  docker service COMMAND
Manage services
Commands:
  create      Create a new service
  inspect     Display detailed information on one or more services
  logs        Fetch the logs of a service or task
  ls          List services
  ps          List the tasks of one or more services
  rm          Remove one or more services
  rollback    Revert changes to a service's configuration
  scale       Scale one or multiple replicated services
  update      Update a service
Run 'docker service COMMAND --help' for more information on a command.
  • 创建一个服务:
docker service create --replicas 1 --name nginx nginx:1.16.1
  • 查看服务
docker service ls
  • 删除服务
docker service rm [服务名]
  • 咳咳,我是想举例着,但是配置给小了,

二.通过docker stack命令创建服务

这种方式运行的是docker-compose模板文件,关于docker-compose请查看我其他文章

  • 可以在服务模板文件中添加deploy指令,并指定副本服务(replicated)数量
  • 我们可以举一个nginx服务的例子
  • 首先需要你安装docker-compose工具,关于这个工具使用:点击这里
  • 模板文件内容:
version: '3'
services:
  nginx:
    image: nginx:1.16.1
    deploy:
      mode: replicated
      replicas: 2
    restart: always
    port: 
      - 80:80
    volumes:
      - /data/nginx/:/etc/nginx
      - /data/webapps/www/:/usr/share/nginx/html/
  • 需要手动创建模板中使用的目录
  • 通过以下命令运行:
docker stack deploy -c docker-compose.yml nginx


  • 通过任意节点的ip:80访问nginx服务

这篇可能有点问题,有问题的话可以留言问我,因为配置给小了,后面做的有点费劲。

目录
相关文章
|
8天前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
130 77
|
16天前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序
|
10天前
|
数据建模 应用服务中间件 nginx
docker替换宿主与容器的映射端口和文件路径
通过正确配置 Docker 的端口和文件路径映射,可以有效地管理容器化应用程序,确保其高效运行和数据持久性。在生产环境中,动态替换映射配置有助于灵活应对各种需求变化。以上方法和步骤提供了一种可靠且易于操作的方案,帮助您轻松管理 Docker 容器的端口和路径映射。
44 3
|
16天前
|
Prometheus 监控 Cloud Native
如何使用Prometheus监控Docker Swarm集群的资源使用情况?
还可以根据实际需求进行进一步的配置和优化,如设置告警规则,当资源使用超出阈值时及时发出警报。通过这些步骤,能够有效地使用 Prometheus 对 Docker Swarm 集群的资源进行监控和管理。
35 8
|
16天前
|
Prometheus 监控 Cloud Native
如何监控Docker Swarm集群的性能?
如何监控Docker Swarm集群的性能?
62 8
|
16天前
|
调度 开发者 Docker
Docker Swarm
Docker Swarm 为容器化应用的部署和管理提供了一种高效、可靠的方式,使开发者能够更轻松地构建和运行分布式应用。随着容器技术的不断发展,Docker Swarm 在企业级应用中的应用也将越来越广泛。
40 8
|
17天前
|
负载均衡 网络协议 算法
Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式
本文探讨了Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式,以及软件负载均衡器、云服务负载均衡、容器编排工具等实现手段,强调两者结合的重要性及面临挑战的应对措施。
44 3
|
17天前
|
存储 安全 数据安全/隐私保护
Docker 容器化应用管理更加高效,但数据安全和业务连续性成为关键。
在数字化时代,Docker 容器化应用管理更加高效,但数据安全和业务连续性成为关键。本文探讨了 Docker 应用的备份与恢复策略,涵盖备份的重要性、内容、方法及常见工具,制定备份策略,恢复流程及注意事项,并通过案例分析和未来趋势展望,强调备份与恢复在保障应用安全中的重要性。
25 2
|
17天前
|
存储 安全 数据中心
Docker 容器凭借轻量级和高效的特性,成为应用部署的重要工具
Docker 容器凭借轻量级和高效的特性,成为应用部署的重要工具。本文探讨了 Docker 如何通过 Namespace 和 Cgroups 实现 CPU、内存、网络和存储资源的隔离,提高系统安全性和资源利用率,以及面临的挑战和应对策略。
32 1
|
17天前
|
存储 缓存 监控
Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
本文介绍了Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
50 7