docker方式搭建DNS服务器

docker方式搭建DNS服务器

1.拉取镜像

# docker pull sameersbn/bind

2.启动bind 服务

bridge桥接网络方式启动:
# docker run --name bind -d --restart=always --publish 53:53/tcp --publish 53:53/udp --publish 10000:10000/tcp --volume /srv/docker/bind:/data sameersbn/bind:latest

host主机网络方式启动:
docker run --name bind -d --restart=always --net host --volume /srv/docker/bind:/data sameersbn/bind:latest
说明:bridge桥接网络方式下dns容器所在宿主机下的其它docker容器dns解析异常,原因未知!host主机网络方式下无法此问题。
个人臆测:可能是docker桥接网络导致的DNS解析请求环路问题。网络环路回流问题常见于不同网络桥接、企业内网端口映射到外网,但访问者通过内网请求外网端口(新一代防火墙已对该问题进行改进,可手动设置)。

错误如下:bad address

/ # ping smtp.example.com
ping: bad address 'smtp.example.com'

3.开启防火墙

# firewall-cmd --add-port 53/udp --permanent
# firewall-cmd --add-port 53/tcp --permanent
# firewall-cmd --add-port 10000/tcp --permanent
# firewall-cmd --reload

4.使用浏览器访问配置页面

https://192.168.103.223:10000/

用户名:root

密码:password

注意:修改配置后,可以通过页面的按钮刷新,也可以直接重启容器使之生效!

# docker restart bind

配置页面
配置1
配置2

新增A记录

5.使用nslookup命令测试

修改CentOS测试机(客户端)DNS

临时修改,重启网卡服务后重置

vim /etc/resolv.conf
清空原先内容后,增加以下内容:
nameserver 192.168.103.223

永久修改

# vim /etc/sysconfig/network-scripts/ifcfg-enp3s0
修改DNS1内容:
DNS1=192.168.103.223

测试命令

windows cmd下可以直接使用以下命令测试:

nslookup node4.example.com

centos需要先按照bind-utils

# yum -y install bind-utils
# nslookup node4.example.com

测试结果:
测试结果

备注:
配置文件持久化目录:
/srv/docker/bind
若有些配置在页面找不到,可以参照网上的其它教程,直接修改相应的配置页面。

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要在Ubuntu上使用Docker搭建DNS服务器,可以按照以下步骤进行操作: 1. 安装Docker 在Ubuntu上安装Docker,可以通过以下命令完成: ``` sudo apt update sudo apt install docker.io ``` 2. 创建一个Docker容器 使用以下命令可以创建一个Docker容器: ``` sudo docker run -d --name dns-server -p 53:53/udp --restart=always --hostname dns.example.com jacobalberty/unbound:latest ``` 这个命令会从Docker Hub上下载jacobalberty/unbound镜像,并在容器中启动unbound DNS服务器。 3. 配置DNS服务器 可以通过以下命令进入容器的shell,并编辑unbound配置文件: ``` sudo docker exec -it dns-server bash vi /etc/unbound/unbound.conf ``` 在配置文件中,可以添加自己需要的DNS解析规则,例如: ``` local-zone: "example.com." redirect local-data: "example.com. IN A 192.168.1.1" ``` 4. 测试DNS服务器 可以使用dig命令测试DNS服务器是否正常工作,例如: ``` dig @localhost example.com ``` 如果返回了上面配置的IP地址,则说明DNS服务器已经正确地解析了域名。 5. 设置客户端DNS服务器 在客户端上,可以将刚才创建的DNS服务器地址添加到/etc/resolv.conf文件中,例如: ``` nameserver 192.168.1.2 ``` 其中,192.168.1.2是刚才创建的DNS服务器的IP地址。这样,客户端就可以使用该DNS服务器进行域名解析了。 以上就是在Ubuntu上使用Docker搭建DNS服务器的步骤。需要注意的是,由于DNS服务器需要使用53号端口,因此在创建Docker容器时需要将该端口映射到主机上。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

搬山境KL攻城狮

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值