使用Docker搭建自己的dns服务器


在开发运维过程中经常需要自定义一个域名来管理服务,通常的方法是修改hosts文件,但还有一种更便捷的方法,从源头上解决问题,也就是使用DNS来实现。

修改hosts: 推荐:Hosts 快速切换工具

1.搭建

搭建依然使用docker,安装前请安装好docker的运行时环境。

# 创建一个持久化存放文件的目录
mkdir -p /opt/docker/bind
# 使用容器创建应用
docker run --name bind -d --restart=always 
  --publish 53:53/tcp --publish 53:53/udp --publish 10000:10000/tcp 
  --volume /opt/docker/bind:/data 
  sameersbn/bind:9.16.1-20200524
使用Docker搭建自己的dns服务器

默认占用53的tcp和udp的DNS访问端口,这个请不要更改,以及10000的管理面板端口。外网访问时,请在防火墙中放行此端口。

firewall-cmd --add-port={53,10000}/tcp --permanent
firewall-cmd --add-port=53/udp --permanent
firewall-cmd --reload

2.访问

使用你的https://ip:10000在浏览器中打开。

使用Docker搭建自己的dns服务器

在高级内打开此网页,使用默认账户密码root/password登录。

使用Docker搭建自己的dns服务器

调整语言为中文,部分菜单可能仍会显示为英文。

使用Docker搭建自己的dns服务器

3.配置

尝试绑定一下dns,依次点击图标中的例子。

使用Docker搭建自己的dns服务器

任意填写一个名称,比如我以cn为域名后缀,填写邮箱,然后点击新建。

使用Docker搭建自己的dns服务器

选择地址。

使用Docker搭建自己的dns服务器

填写域名和ip地址。

使用Docker搭建自己的dns服务器
image

可以看到我们的aaa.cn域名,已经解析到192.168.31.92这个ip上了。

使用Docker搭建自己的dns服务器
image

重启一下服务,执行以下命令,这样才能使用配置生效:

docker restart bind

4.使用

将电脑的dns地址指向服务器地址,比如我在Mac下修改DNS地址。Windows修改方式类似。

使用Docker搭建自己的dns服务器

如果是公网就填公网地址。做一下ping测试,发现已经正常解析了。

使用Docker搭建自己的dns服务器
image

到这个时候,其实还有一个问题,就是除了我们设置的域名之外的网站是无法访问的。如果想访问百度之类的公网网站,进行如下设置:

vim /opt/docker/bind/bind/etc/resolv.conf

加入以下DNS地址:

nameserver 114.114.114.114
nameserver 8.8.8.8

修改另一个配置文件:

vim /opt/docker/bind/bind/etc/named.conf.options

添加一行,内容如下:

allow-query { any; };
使用Docker搭建自己的dns服务器

再次重启一下bind服务,发现已经可以正常地访问互联网了,同时也能正常访问自定义的域名。

最后放上github的地址:

https://hub.docker.com/r/sameersbn/bind

往期推荐:

  1. Windows下手动安装MySQL-5.7.32,完整详细教程

  2. 免费的异地组网神器Docker搭建教程-ZeroTiger

  3. 基于Docker的FRP内网穿透部署

原文始发于微信公众号(运维贼船):使用Docker搭建自己的dns服务器

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/177210.html

(0)
小半的头像小半

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!