注意:该仓库已被弃用。
Datadog Docker Socket Filter 是一个基于 HAProxy 的过滤代理,用于提供对 Docker 管理 socket 的只读访问权限。它通过 HTTP 代理机制过滤 Docker API 请求,只允许特定的安全只读操作,从而降低直接暴露 Docker socket 带来的安全风险。
GET 和 HEAD HTTP 请求方法,阻止所有可能修改系统状态的 POST、PUT 和 DELETE 请求/safe-docker 目录创建安全 socket,与原始 Docker socket 隔离Docker 引擎没有专门的监控接口,只能通过管理 socket 访问容器/镜像/卷等信息。直接暴露 Docker socket (/var/run/docker.sock) 存在严重安全风险,因为所有发送到该 socket 的命令都以 root 权限执行,可能被***者利用作为权限提升途径。
Docker 官方的授权子系统存在以下缺点:
为需要访问 Docker API 获取监控数据的应用(如 Datadog Agent)提供安全的只读访问通道,同时防止潜在的权限滥用和安全风险。
Docker 管理 API 是标准的 HTTP REST API,可通过 HTTP 代理进行过滤。该容器使用 HAProxy 提供 API 的只读访问,通过在 /safe-docker 挂载的共享卷中创建安全 socket 实现:
GET/HEAD 请求,所有修改系统状态的操作(POST、PUT 或 DELETE)均被阻止经过过滤的安全端点可通过安全 socket 供监控软件访问。
参考示例 docker-compose 文件进行部署:
yamlversion: '3' services: docker-filter: image: datadog/docker-filter:latest volumes: - /var/run/docker.sock:/var/run/docker.sock - safe-docker:/safe-docker # 其他配置... volumes: safe-docker:
bashdocker run -d \ --name docker-filter \ -v /var/run/docker.sock:/var/run/docker.sock \ -v safe-docker-volume:/safe-docker \ datadog/docker-filter:latest
主要配置文件
安全 Socket 访问
安全的 Docker API Socket 位于共享卷的 /safe-docker 目录下,可挂载到需要访问 Docker API 的监控容器中使用。
在 docker-filter 容器内部,可以访问 haproxy.sock 进行故障排查。有关如何使用 HAProxy socket 进行故障排除的更多信息,请参阅 如何收集 HAProxy 指标 中的 "Socket 通信" 部分。
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
docker search 限制
站内搜不到镜像
离线 save/load
插件要用 plugin install
WSL 拉取慢
安全与 digest
新手拉取配置
镜像合规机制
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
域名连通性排查
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务