gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-01 19:50:43 27 4
gpt4 key购买 nike

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

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

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

这很重要,因为我必须 manually delete unused images否则,当没有更多磁盘空间时,机器将面临崩溃的风险。因此,弄清楚任务运行的位置是此过程的第一步,哈哈。

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

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

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

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

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

到目前为止,我一定已经尝试了十亿种不同的技巧。

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

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

我正在运行 Docker 版本 17.06.2。

最佳答案

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

docker inspect <task ID> --format '{{.NodeID}}'

使用节点 ID 获取节点 IP:

docker inspect <node ID> --format '{{.Status.Addr}}'

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

docker inspect -f '{{.Status.Addr}}' $(docker inspect -f '{{.NodeID}}' <task ID>)

作为奖励,MAC 地址:

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

关于docker - 在 Docker Swarm 中,如何找到哪个节点 IP 正在运行给定任务?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46159302/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com