0

我正在尝试使用 dockerode 访问 Docker API。

我的目标是获取多节点集群中所有容器的容器数据。

似乎它docker.listContainers( {all: true } )的范围仅返回在调用节点上运行的容器,在我的例子中是我的管理器节点。 https://docs.docker.com/engine/api/v1.37/#operation/ContainerList

  1. 我们如何使用 dockerode 获取 swarm 中所有容器的列表?

  2. 我们如何使用 dockerode 获取与服务关联的所有容器的列表?

在命令行中,你可以通过获取容器iddocker service ps <service_name>来获取容器id,然后调用inspect on container。

$ docker service ps classifier_8
ID                  NAME                IMAGE                                 NODE                DESIRED STATE       CURRENT STATE            ERROR               PORTS
m1x8e2w5dyvr        classifier_8.1      scuba:qa-latest  master         Running             Running 26 minutes ago
8a04d2e18ee9        classifier_8.2      scuba:qa-latest  worker-0         Running             Running 26 minutes ago
a6b48751780b        classifier_8.3      scuba:qa-latest  worker-1         Running             Running 26 minutes ago

$ docker inspect a6b48751780b
[{...}]

即使是调用 dockerode.getContainer(a6b48751780b) 的简单示例也会返回 404。调用 m1x8e2w5dyvr 会返回管理节点上的预期数据。

4

1 回答 1

1

docker API 只会在使用GET /containers/json端点时返回本​​地运行的容器,因此在尝试返回另一个 docker 引擎上的容器时会出现 404。Swarm 管理器只能返回整个集群的 swarm 对象。常规容器不是群体对象。

与 swarm 模式交互时,可以列出 swarm 服务和 swarm 任务。GET /servicesGET /tasks。由于任务确实是一个集群模式对象,您可以从任何管理器列出整个集群的所有任务。

然后任务继续在集群中的各个节点上创建容器。如果要列出整个 swarm 中的容器,则必须GET /containers/json直接在每个节点上使用 API 端点。

这些 API 端点类似于以下命令:

  • GET /containers/json-docker container ls
  • GET /services-docker service ls
  • GET /tasks?filter=...- docker service ps ...(有关正确的过滤语法,请参阅文档)

我已经在 Docker API 的上下文中而不是在任何一个 docker API 库的上下文中回答了这个问题,以提高可读性。

于 2021-01-22T15:04:51.317 回答