问题描述
我正在尝试使用 dockerode 访问 Docker API。
我的目标是获取多节点集群中所有容器的容器数据。
看来 docker.listContainers( {all: true } )
的范围仅限于返回在调用节点上运行的容器,在我的例子中是我的管理器节点。
https://docs.docker.com/engine/api/v1.37/#operation/ContainerList
在命令行中,您可以使用docker service ps <service_name>
获取容器ID,然后在容器上调用inspect。
$ 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 会返回预期数据作为管理器节点上的数据。
解决方法
当使用 GET /containers/json
端点时,docker API 将仅返回本地运行的容器,因此在尝试返回另一个 docker 引擎上的容器时会出现 404。 Swarm 管理器只能返回整个集群的 swarm 对象。常规容器不是群对象。
在与 swarm 模式交互时,您可以列出 swarm 服务和 swarm 任务。 GET /services
和 GET /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 库的上下文中回答了这个问题。