本站支持搜索的镜像仓库:Docker Hub、gcr.io、ghcr.io、quay.io、k8s.gcr.io、registry.gcr.io、elastic.co、mcr.microsoft.com

DNS Collector 是一款针对DNS消息的被动高速处理工具,主要功能包括DNS消息的聚合、分析、传输和日志记录。该工具支持多种DNS数据收集方式,提供灵活的数据转换和路由能力,并可将处理结果输出至控制台、文件、API接口或Prometheus等多种目标,适用于DNS流量监控、安全分析和性能评估场景。
通过以下命令启动容器,挂载自定义配置文件:
docker run -d dmachard/go-dnscollector -v $(pwd)/config.yml:/etc/dnscollector/config.yml
创建docker-compose.yml文件,配置如下:
version: "3.8" services: dnscollector: image: dmachard/go-dnscollector:v0.25.0 environment: - "TZ=Europe/Paris" # 设置时区 volumes: - ${APP_CONFIG}/dnscollector/config.yml:/etc/dnscollector/config.yml # 挂载配置文件 - ${COLLECTOR_DATA}/:/var/dnscollector/ # 挂载数据目录(用于日志存储) ports: - "8080:8080/tcp" # REST API端口 - "8081:8081/tcp" # Prometheus指标端口 - "6000:6000/tcp" # DNS数据收集端口
DNS Collector 通过config.yml文件进行配置,核心结构包括全局配置(global)和多路复用器配置(multiplexer)。
用于设置全局跟踪参数:
global: trace: verbose: true # 启用详细日志 log-malformed: true # 记录格式错误的DNS消息
包含收集器(collectors)、记录器(loggers)和路由规则(routes)三部分。
定义DNS数据的来源,支持多种收集方式:
collectors: - name: tap # 收集器名称 powerdns: # PowerDNS收集协议配置 listen-ip: 0.0.0.0 # 监听IP listen-port: 6000 # 监听端口 transforms: # 数据转换配置 normalize: # 归一化处理 qname-lowercase: true # 将查询域名转为小写 add-tld: true # 添加顶级域名(TLD)信息 suspicious: # 可疑请求检测 enable: true # 启用可疑请求检测
定义数据输出目标,支持多种输出方式:
loggers: - name: console # 控制台输出 stdout: mode: text # 输出格式:文本 - name: json # 日志文件输出 logfile: file-path: /var/dnscollector/dnstap.log # 日志文件路径 mode: text # 输出格式:文本 - name: api # REST API输出 restapi: listen-ip: 0.0.0.0 # API监听IP listen-port: 8080 # API监听端口 - name: prom # Prometheus指标输出 prometheus: listen-ip: 0.0.0.0 # Prometheus监听IP listen-port: 8081 # Prometheus监听端口
定义数据从收集器到记录器的流转路径:
routes: - from: [ tap ] # 来源收集器(对应collectors中的name) to: [ console, json, api, prom ] # 目标记录器(对应loggers中的name)
免费版仅支持 Docker Hub 加速,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
免费版仅支持 docker.io;专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录方式配置轩辕镜像加速服务,包含7个详细步骤
在 Linux 系统上配置轩辕镜像源,支持主流发行版
在 Docker Desktop 中配置轩辕镜像加速,适用于桌面系统
在 Docker Compose 中使用轩辕镜像加速,支持容器编排
在 k8s 中配置 containerd 使用轩辕镜像加速
在宝塔面板中配置轩辕镜像加速,提升服务器管理效率
在 Synology 群晖NAS系统中配置轩辕镜像加速
在飞牛fnOS系统中配置轩辕镜像加速
在极空间NAS中配置轩辕镜像加速
在爱快ikuai系统中配置轩辕镜像加速
在绿联NAS系统中配置轩辕镜像加速
在威联通NAS系统中配置轩辕镜像加速
在 Podman 中配置轩辕镜像加速,支持多系统
配置轩辕镜像加速9大主流镜像仓库,包含详细配置步骤
无需登录即可使用轩辕镜像加速服务,更加便捷高效
需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429