在 Docker Swarm 中,如何找到哪个节点 IP 正在运行给定任务?

Mar*_*son 5 entity task identifier docker docker-swarm

问题标题是我想要解决的具体问题。但更简单的是,是否可以列出服务中的所有任务以及运行它们的节点 IP?

docker service ps将列出任务 ID 以及正在运行该任务的节点的主机名。没有提供其他节点标识符,例如 ID 或 IP。

但我使用 Vagrant 来管理虚拟机,并且没有配置主机名,所有主机名都命名为相同(“vagrant”)。这使得我很难准确地找出哪个节点正在运行该任务!

这很重要,因为我必须手动删除未使用的图像,否则当没有更多磁盘空间时,机器将面临崩溃的风险。因此,弄清楚任务运行的位置是此过程的第一步,哈哈。

对于 Vagrant 用户来说,我使用该选项在 Vagrantfile 中轻松更改了主机名config.vm.hostname。但当然,这个问题仍然是完全合理的。

我可以在每个节点上手动运行docker imagesordocker ps来找出哪个节点存储预期的图像和/或当前正在运行哪个容器(容器名称将是任务 ID 和任务名称的串联,用点分隔)。但这很麻烦。

我还可以列出所有节点及其 ID,docker node ls然后寻找每个节点的任务,例如使用docker node ps 7b(“7b”是我的一个节点 ID 中的前两个字母)。但这也很麻烦,而且我最多“只”了解节点 ID 而不是 IP。

但是,我可以使用节点 ID 和如下命令找到 IP:docker inspect 7b --format '{{.Status.Addr}}'。因此,直接获取 IP 并不是一个严格的要求,并且一度 - 当我理解这一点时 - 我认为找到给定任务 ID 的节点 ID 会容易得多!

但不是。连这似乎都是不可能的事?如前所述,docker service ps没有给我节点 ID。该命令的文档.Name说占位符应该给我“节点 ID”,但这是错误的。

直到这一刻我一定已经尝试了十亿种不同的技巧。

我觉得特别令人不安的一件事是该命令的文档docker node ps明确指出它可以用于“列出在一个或多个节点上运行的任务”(强调我的)。但如果我这样做:docker node ps vagrant我收到一条错误消息,指出主机名不明确,因为它解析为多个节点!哈哈,没那么有趣(即使不使用主机名,我也没有得到这个命令来列出多个节点上的任务)。这并不重要,因为docker node ps就像docker service ps甚至不输出节点 ID 一样,这两个命令的文档都谎称能够这样做。

所以你有它。我想知道我面前是否有一些我错过的东西,或者整个世界都依赖于独特的主机名吗?感觉就像我必须错过一些显而易见的事情。当然,如此受欢迎的产品 Docker 一定能够提供一种在给定任务 ID 的情况下查找节点 ID 或节点 IP 的方法吗?唔。

我正在运行 Docker 版本 17.06.2。

Mar*_*son 4

这给了我节点 ID,给定 <task ID>:

docker inspect <task ID> --format '{{.NodeID}}'
Run Code Online (Sandbox Code Playgroud)

使用节点 ID 获取节点 IP

docker inspect <node ID> --format '{{.Status.Addr}}'
Run Code Online (Sandbox Code Playgroud)

或者,全部集中在一个压缩行中:

docker inspect -f '{{.Status.Addr}}' $(docker inspect -f '{{.NodeID}}' <task ID>)
Run Code Online (Sandbox Code Playgroud)

作为奖励,MAC 地址:

docker inspect -f '{{.NetworkSettings.Networks.ingress.MacAddress}}' $(docker inspect -f '{{.Status.ContainerStatus.ContainerID}}' <task ID>)
Run Code Online (Sandbox Code Playgroud)