编程技术分享平台

网站首页 > 技术教程 正文

用Raspberry pi搭建私有DNS服务器

xnh888 2024-11-07 13:17:43 技术教程 27 ℃ 0 评论

在家庭或者小企业的局域网中,有一些固定IP的服务器,比方说NAS、网络打印机、路由器、内部网站等等,访问这些地址通常需要通过IP地址直接访问或者花钱购买域名,如果我们在局域网中搭建私有DNS服务器,就可以随心所欲的使用一个实际不存在域名给我们的局域网服务器使用。

今天就带大家利用Raspberry pi(树莓派)和dnsmasq来搭建局域网私有DNS服务。首先我们在Raspberry pi上安装linux操作系统,这里推荐使用官方的Raspbian,并且将树莓派的IP设置为固定的IP。具体安装与设置可以参考网上相关文章。

我们首先通过apt-get安装dnsmasq

sudo apt-get install dnsmasq

然后在/etc/dnsmasq.d/中创建一个文件,可以命名为address.conf

在这个文件中设置你想要设置的域名与ip的对应关系(A记录),例如:

address=/nas.hodor.me/192.168.0.3
address=/router.hordor.me/192.168.0.1

然后在/etc目录下创建文件resolv.dnsmasq.conf,文件内容为上游DNS服务器的地址,如:

nameserver 223.5.5.5
nameservel 8.8.8.8
nameserver 223.6.6.6
nameserver 114.114.114.114

编辑/etc/dnsmasq.conf文件,主要修改以下部分:

resolv-file=/etc/resolv.dnsmasq.conf # 从上面的resolv.dnsmasq.conf文件获取上游DNS服务器
strict-order # 严格按照revolv-file里面的定义的顺序使用上游dns解析
conf-file=/etc/dnsmasq.d/address.conf # 指定上面的address.conf为额外的配置文件

通过以下命令启动dnsmasq

sudo service dnsmasq restart # start|stop

编辑/etc/resolv.conf将Raspberry Pi自己的dns服务器改为自身:

nameserver 127.0.0.1

此时可以用dig命令看一下是否生效(如果没有dig的话可以通过sudo apt-get install dnsutils安装)

pi@raspberrypi:/etc $ dig nas.hodor.me
; <<>> DiG 9.11.5-P4-5.1-Raspbian <<>> nas.hodor.me
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 15005
;; flags: qr aa rd ra ad; QUERY: 1, ANSWER: 1, AUTHORITY: 0, ADDITIONAL: 1
;; OPT PSEUDOSECTION:
; EDNS: version: 0, flags:; udp: 4096
;; QUESTION SECTION:
;nas.hodor.me. IN A
;; ANSWER SECTION:
nas.hodor.me. 0 IN A 192.168.0.3
;; Query time: 0 msec
;; SERVER: 127.0.0.1#53(127.0.0.1)
;; WHEN: Mon Feb 10 17:34:16 CST 2020
;; MSG SIZE rcvd: 54

如果在ANSWER SECTION中能看到对应的A记录,那恭喜你,设置成功了!

最后只需要去路由器的dhcp设置里把dns设置为Raspberry Pi的地址,就大功告成了。

如果我们后续需要增加或者修改自定义的A记录,只需要修改/etc/dnsmasq.d/address.conf后,使用以下命令即可生效:

sudo service dnsmasq reload

有一点需要提醒大家注意的是:虽然理论上你可以把域名设置成任何你想要的值,但某些浏览器会根据这个字符串是否是有效的顶级域名来确定是进行搜索还是打开网页,所以建议还是使用有效的.com/.net/.me等顶级域名来作为你的域名结尾。

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表