Docker Swarm Mode网络诊断工具

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: Docker CE 从17.12版本开始加入网络调试的工具,使用这个工具可以帮助排查Linux上的docker overlay网络以及swarm service的问题

(文章翻译自https://github.com/fcrisciani/libnetwork/blob/be91c3ed62817bc3899ebe154eea07c573395b0c/cmd/diagnostic/README.md)


Docker CE 从17.12版本开始加入网络调试的工具,使用这个工具可以帮助排查Linux上的docker overlay网络以及swarm service的问题。当开启网络调试选项时,Docker daemon会在指定的端口启动一个网络诊断的服务以提供网络诊断信息的获取。这个调试工具只建议在需要排查特定的网络问题时开启,不应该一直开启着这个调试服务。

被保存在数据库中的网络的信息可以通过诊断的API获取到,目前这个数据库中主要包含了overlay网络的数据,以及服务发现的数据。

Docker目前也提供了一个预览版的CLI的集成工具,这个工具通过访问Docker暴露的诊断API来查询和控制网络的接口,但这个工具的实现和命令选项并没有完全确定下来,后续可能随时会改变。

目前可以以下两种方式来使用这个调试工具:

  • 只有客户端的工具的镜像:dockereng/network-diagnostic:onlyclient
  • Docker in docker的镜像: dockereng/network-diagnostic:17.12-dind

Docker in docker的方式提供的工具是为了在集群版本小于17.12中使用,利用这个镜像中的Docker去获取到集群的网络信息。

打开诊断服务

这个工具目前只能在Linux上的Docker节点使用,通过下面的步骤打开:

  1. 通过在/etc/docker/daemon.json中配置network-diagnostic-port,在节点上设置一个空闲的端口分配给诊断服务:

    "network-diagnostic-port": <port>
  2. 使用下面这个命令找到dockerd的进程id(PID):

    $ ps aux |grep dockerd | grep -v grep
  3. 不需要重启Docker daemon,直接通过发送HUP信号给刚才找到的进程ID来reload配置:

    kill -HUP <pid-of-dockerd>

如果Docker是用systemd启动的,上面这一步也可以直接使用systemctl reload docker来reload配置。reload之后可以在docker的日志看到:

Starting the diagnostic server listening on <port> for commands

关闭诊断服务

  1. /etc/docker/daemon.json中移除掉network-diagnostic-port的配置
  2. 像上面一样找到dockerd的进程ID
  3. 像上面一样reload下dockerd的配置 reload后可以看到dockerd打出如下日志:
Disabling the diagnostic server

诊断API

诊断的API通过http暴露到上面指定的端口上,通过HTTP请求访问这个端口来访问这个诊断API,下面的命令中我们假定定义的端口是20000

例如:

获取API帮助(API列表):

$ curl localhost:2000/help

OK
/updateentry
/getentry
/gettable
/leavenetwork
/createentry
/help
/clusterpeers
/ready
/joinnetwork
/deleteentry
/networkpeers
/
/join

加入或离开网络集群

$ curl localhost:2000/join?members=ip1,ip2,...
$ curl localhost:2000/leave?members=ip1,ip2,...

ip1, ip2, ... 这些是swarm集群中的其他节点IP

添加或者删除掉一个网络

$ curl localhost:2000/joinnetwork?nid=<network id>
$ curl localhost:2000/leavenetwork?nid=<network id>

network id 可以在swarm集群的manager节点中通过docker network ls --no-trunc看到,这里必须使用完整的network id

罗列集群的peer

$ curl localhost:2000/clusterpeers

罗列拥有某个网络的节点列表

$ curl localhost:2000/networkpeers?nid=<network id>

network id 可以在swarm集群的manager节点中通过docker network ls --no-trunc看到,这里必须使用完整的network id

Dump 网络信息数据库的表

这些表包含 endpoint_tableoverlay_peer_tableoverlay_peer_table中包含了网络的转发信息。 endpoint_table包含了服务发现的信息。

$ curl localhost:2000/gettable?nid=<network id>&tname=<table name>

修改指定的数据库表

这些表包含 endpoint_tableoverlay_peer_table

$ curl localhost:2000/<method>?nid=<network id>&tname=<table name>&key=<key>[&value=<value>]

注意:这里只是更新了执行的节点上的表,这意味着在这个节点同步集群之前会一直保持着这个更新的值。

使用诊断的客户端来访问网络信息

这个工具的实现和命令选项并没有完全确定下来,后续可能随时会改变。 这个工具可以直接通过执行一个的镜像中的diagnosticClient可执行文件来调用网络信息。

docker run --net host dockereng/network-diagnostic:onlyclient -v -net <full network id> -t sd

下面是支持的命令:

选项 描述
-t  访问的table的名称 sd  overlay.
-ip  要访问的API的IP地址. 默认是 127.0.0.1.
-net  The target network ID.
-port  要访问的API的端口. 默认是 2000
-v 显示verbose级别日志

Docker in docker版本的诊断工具

这个命令行工具内置了docker 17.12的docker daemon,并且需要以privileged模式运行。
注意: 每个更新操作例如(create entry)只是更新了执行的节点上本地的表,这意味着在这个节点同步集群之前会一直保持着这个更新的值。

  1. 保证诊断的节点不在集群中,如果已经加入到了一个集群中,可以docker swarm leave -f离开集群
  2. 可以使用下面这个命令来启动这个容器:

    $ docker container run --name net-diagnostic -d --privileged --network host dockereng/network-diagnostic:17.12-dind
  3. 通过docker exec -it <container-ID> sh进入到这个容器中,使用下面这个命令启动诊断服务器:

    $ kill -HUP 1
  4. 把诊断容器的docker daemon加入到已有的docker swarm集群中,然后再容器中执行诊断的可执行工具。

    $ ./diagnosticClient <flags>...
  5. 完成诊断后,离开现有的这个集群,并停止这个诊断容器。

示例:

下面的这些命令会dump下来服务发现的表以及验证和集群别的节点的关系:

注意: 使用完整的网络ID,网络ID可以方便的通过docker network ls --no-trunc获取到。

服务发现和负载均衡:

$ diagnostiClient -c sd -v -net n8a8ie6tb3wr2e260vxj8ncy4

Overlay网络:

$ diagnostiClient -port 2001 -c overlay -v -net n8a8ie6tb3wr2e260vxj8ncy4
目录
相关文章
|
10天前
|
NoSQL 关系型数据库 MySQL
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
109 56
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
|
23天前
|
存储 监控 C++
11 个必备 Docker 工具
11 个必备 Docker 工具
130 11
11 个必备 Docker 工具
|
22天前
|
安全 Docker 容器
docker的默认网络模式有哪些
Docker 默认网络模式包括:1) bridge:默认模式,各容器分配独立IP,可通过名称或IP通信;2) host:容器与宿主机共享网络命名空间,性能最优但有安全风险;3) none:容器隔离无网络配置,适用于仅需本地通信的场景。
35 6
|
25天前
|
Prometheus 监控 Cloud Native
如何使用Prometheus监控Docker Swarm集群的资源使用情况?
还可以根据实际需求进行进一步的配置和优化,如设置告警规则,当资源使用超出阈值时及时发出警报。通过这些步骤,能够有效地使用 Prometheus 对 Docker Swarm 集群的资源进行监控和管理。
43 8
|
25天前
|
Prometheus 监控 Cloud Native
如何监控Docker Swarm集群的性能?
如何监控Docker Swarm集群的性能?
82 8
|
25天前
|
调度 开发者 Docker
Docker Swarm
Docker Swarm 为容器化应用的部署和管理提供了一种高效、可靠的方式,使开发者能够更轻松地构建和运行分布式应用。随着容器技术的不断发展,Docker Swarm 在企业级应用中的应用也将越来越广泛。
48 8
|
25天前
|
存储 缓存 监控
Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
本文介绍了Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
66 7
|
25天前
|
监控 Docker 容器
Docker Swarm集群的扩展与缩容策略,涵盖其意义、方法、步骤及注意事项
本文深入探讨了Docker Swarm集群的扩展与缩容策略,涵盖其意义、方法、步骤及注意事项,旨在帮助用户高效管理集群资源,适应业务变化,确保服务稳定性和资源优化。
48 6
|
25天前
|
存储 安全 数据中心
Docker 容器凭借轻量级和高效的特性,成为应用部署的重要工具
Docker 容器凭借轻量级和高效的特性,成为应用部署的重要工具。本文探讨了 Docker 如何通过 Namespace 和 Cgroups 实现 CPU、内存、网络和存储资源的隔离,提高系统安全性和资源利用率,以及面临的挑战和应对策略。
43 1
|
1月前
|
安全 网络安全 数据安全/隐私保护
利用Docker的网络安全功能来保护容器化应用
通过综合运用这些 Docker 网络安全功能和策略,可以有效地保护容器化应用,降低安全风险,确保应用在安全的环境中运行。同时,随着安全威胁的不断变化,还需要持续关注和研究新的网络安全技术和方法,不断完善和强化网络安全保护措施,以适应日益复杂的安全挑战。
44 5