
pwa666/bind9Bind9 镜像是一个基于 Alpine Linux 的轻量级容器,集成了 Bind9 DNS 服务器和 Webmin 管理界面。该镜像旨在提供简单易用的 DNS 服务部署方案,同时支持通过 Web 界面便捷管理 Bind9 配置。自 2.1.x 版本起,镜像提供多架构支持。
bind9、bind9-tools(工具集)、bind9-dnssec(DNSSEC 支持)logging {} 块从源码构建镜像:
bashdocker build -t <镜像名称>:<标签> .
直接运行容器(基础示例):
bashdocker run -d \ --name bind9-server \ -v /本地路径/bind/config:/etc/bind \ # 挂载 Bind 配置目录 -e TZ="Asia/Shanghai" \ # 设置时区 -e GUI_USER="admin" \ # 自定义 Webmin 用户名 -e GUI_PASSWORD="mypassword" \ # 自定义 Webmin 密码 -p 53:53/udp \ # DNS 服务端口(UDP) -p ***:***/tcp \ # Webmin 管理端口(TCP) --restart always \ <镜像名称>:<标签>
创建 docker-compose.yml 文件:
yamlversion: '3' services: bind: image: <镜像名称>:<标签> volumes: - "/本地路径/bind/config:/etc/bind" # 挂载本地 Bind 配置目录 restart: always environment: TZ: "Asia/Shanghai" # 时区(如 "Region/City" 格式) GUI_USER: "admin" # Webmin 用户名(可选,默认:admin) GUI_PASSWORD: "mypassword" # Webmin 密码(可选,默认:difficult) IPV6: "disable" # IPv6 开关(可选,默认:disable) EXTEND_LOGGING: "false" # 扩展日志开关(可选,默认:false) ports: - "53:53/udp" # DNS 服务端口(UDP) - "***:***/tcp" # Webmin 管理端口(TCP) # 可选:使用 host 网络模式(替代 ports 映射,直接使用主机网络) # network_mode: host
启动服务:
bashdocker-compose up -d
/etc/bind:Bind 配置文件目录。需将本地配置目录挂载至此,实现配置持久化和自定义。示例:-v /local/bind/config:/etc/bind| 端口 | 协议 | 用途 |
|---|---|---|
| 53/udp | UDP | DNS 服务端口 |
| ***/tcp | TCP | Webmin 管理界面端口 |
替代方案:若使用
network_mode: host,无需单独映射端口,容器直接使用主机网络。
| 环境变量 | 默认值 | 取值范围 | 说明 |
|---|---|---|---|
TZ | - | Region/City | 容器时区,如 "Asia/Shanghai"、"Europe/London" |
GUI_USER | admin | 字符串 | Webmin 管理界面登录用户名 |
GUI_PASSWORD | difficult | 字符串 | Webmin 管理界面登录密码 |
IPV6 | disable | enable/disable | 是否启用 IPv6 支持 |
EXTEND_LOGGING | false | true/false | 是否开启扩展日志模式。true 时允许在 Bind 配置文件中自定义 logging {} 块 |



manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务