在监控容器时,通常需要从 Docker 中获取容器的信息,如果监控服务和其他的服务在同一台宿主机上,通常可以直接通过挂载 socket 的方式进行获取;但是为了监控的准确性,通常会将监控服务和其他服务分开部署,因此需要从外部获取 Docker 容器信息;

Docker 除了支持 socket 方式之外,还支持通过 HTTP 的方式获取容器的信息

开启 HTTP 访问

HTTP 访问是通过在启动 Docker 服务的时候添加参数的方式开启的;需要在 docker service 的启动命令中添加 -H tcp://0.0.0.0:2375 -H unix://var/run/docker.sock,即允许通过 HTTP 方式和 socket 方式访问

配置启动参数

该文件是 docker 服务的定义文件

vi /usr/lib/systemd/system/docker.service

在 Service 的 ExecStart 命令中添加 -H tcp://0.0.0.0:2375 -H unix://var/run/docker.sock

[Service]
Type=notify
# the default is not to use systemd for cgroups because the delegate issues still
# exists and systemd currently does not support the cgroup feature set required
# for containers run by docker
ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock -H tcp://0.0.0.0:2375 -H unix://var/run/docker.sock
ExecReload=/bin/kill -s HUP $MAINPID
TimeoutStartSec=0
RestartSec=2
Restart=always

重启 Docker 服务

systemctl daemon-reload
systemctl restart docker

检查端口

通过 telnet 命令检查 2375 端口,可以访问说明端口正常

telnet localhost 2375
Trying ::1...
Connected to localhost.
Escape character is '^]'.

开启防火墙

在外部访问时还需要开启防火墙,将 2375 端口添加到放行名单中即可;添加后在外部通过 telnet 检查也可以访问说明配置成功了

firewall-cmd --zone=public --add-port=2375/tcp --permanent