
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
多架构Docker镜像,基于Alpine,可通过环境变量完全配置,用作本地DHCP和/或DNS服务器。
本镜像旨在提供一个可通过环境变量完全配置的DNS/DHCP服务器解决方案,遵循12因素应用原则,实现无状态容器运行。不再基于andyshinn/dnsmasq镜像(该镜像已过时),主要用于简单/家庭环境的DNS和DHCP设置。
1. 创建环境变量文件
bashdocker run --rm -it drpsychick/dnsmasq:latest --test docker run --rm -it drpsychick/dnsmasq:latest --export > dnsmasq.env
2. 运行容器
在单独的终端中执行:
bashdocker run --rm -it --cap-add NET_ADMIN --env-file dnsmasq.env --name dnsmasq-1 drpsychick/dnsmasq:latest -k -q --log-facility=-
3. 测试服务
bash# 测试DNS和DHCP container_ip=$(docker inspect dnsmasq-1 -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}') docker_interface=$(docker network inspect bridge -f '{{index .Options "com.docker.network.bridge.name"}}') nslookup google.com $container_ip # 测试DHCP(需要管理员权限) sudo ip link add test0 link docker0 type macvlan mode bridge sudo dhclient -1 -d -s $container_ip test0 sudo ip link del test0 link docker0 type macvlan mode bridge
如果因新增默认网关导致路由问题(可通过route -n检查),执行以下命令修复:
bashsudo route del -net 172.17.10.0/24 gw 172.10.10.1 dev $docker_interface
要使容器从本地子网获取IP并为子网提供服务,需要进行额外配置(若无需DHCP服务,可跳过大部分步骤)。
DHCP服务仅在其运行的接口所在子网范围内生效,即DHCP服务需要在其提供服务的子网中拥有一个IP地址。
假设网络环境:
1. 创建环境变量文件(dnsmasq.env)
envDMQ_DNS_HOST1=gateway,gateway.local,192.168.1.1 DMQ_DHCP_GATEWAY=dhcp-option=3,192.168.1.1 DMQ_DHCP_RANGES=dhcp-range=192.168.1.110,192.168.1.120,24h DMQ_DHCP_DNS=dhcp-option=6,192.168.1.253,8.8.8.8,8.8.4.4
测试配置是否正确:
bashdocker run --rm -it --env-file dnsmasq.env drpsychick/dnsmasq:latest --test
2. 配置网络(macvlan)
为使容器从本地子网获取IP,需使用macvlan驱动;为使主机能与容器通信,需创建虚拟接口:
bash# 创建链接接口mac0(替代物理接口eth1) sudo ip link add mac0 link eth1 type macvlan mode bridge sudo ip addr flush dev eth1 sudo dhclient mac0 # 创建macvlan网络(本地子网) docker network create --driver macvlan --subnet 192.168.1.0/24 --gateway 192.168.1.1 -o parent=mac0 local-net
3. 运行容器(测试模式)
在单独终端中执行:
bashdocker run --rm -it --net local-net --ip 192.168.1.253 --cap-add NET_ADMIN --env-file dnsmasq.env --publish 53:53 --publish 53:53/udp --publish 67:67/udp --name dnsmasq-1 drpsychick/dnsmasq:latest -k -q --log-facility=-
4. 测试服务
bash# 测试DNS nslookup google.de 192.168.1.253 # 测试DHCP(需要管理员权限) sudo ip link add mac1 link eth1 type macvlan mode bridge sudo dhclient -1 -d -s 192.168.1.253 mac1 sudo ip link del mac1
5. 生产环境部署
bash# 后台运行并设置自动重启 docker run -d --net local-net --ip 192.168.1.253 --cap-add NET_ADMIN --env-file dnsmasq.env --restart always --publish 53:53 --publish 53:53/udp --publish 67:67/udp --name dnsmasq-1 drpsychick/dnsmasq:latest -k -q --log-facility=- # 查看日志 docker attach --sig-proxy=false dnsmasq-1
对于非DHCP服务,可通过以下简化方式部署:
bash# 为物理接口添加IP sudo ip addr add 192.168.1.253/32 dev eth1 # 运行容器(指定IP发布端口) docker run ... --publish 192.168.1.253:53:53 ...
自动化构建灵感来源于:
以下是 drpsychick/dnsmasq 相关的常用 Docker 镜像,适用于 不同场景 等不同场景:
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。



来自真实用户的反馈,见证轩辕镜像的优质服务