自建 DNS 服务器,能够规避运营商的 DNS 劫持,还能够必定程度上加速网络访问。除此以外,在自定一些配置以后,能实现广告拦截及其余的一些功能。在这里咱们经过在树莓派使用 dnsmasq 搭建这样一个 DNS 服务器。git
sudo apt-get install dnsmasq
首先备份一下原配置文件,命令行以下:github
sudo cp /etc/dnsmasq.conf /etc/dnsmasq.conf.bak
接着编辑配置文件,命令行以下:缓存
sudo vi /etc/dnsmasq.conf
这里,咱们首先按下 esc 进入命令模式,而后使用快捷键 yddG 清空文件,以后使用 i 进入插入模式,ctrl+v 粘贴以下配置内容,粘贴完成后按下 esc,最后使用 :wq 保存文件:服务器
resolv-file=/etc/my_dns.conf strict-order cache-size=10000 listen-address=127.0.0.1,192.168.1.37 address=/pi.com/192.168.1.37
其中 192.168.1.37
为树莓派的局域网 ip,address=/pi.com/192.168.1.37
是为了测试规则并将树莓派上的网站解析到 pi.com
。网络
其他各项解释:测试
resolve-file:定义 dnsmasq 的上游DNS服务器,默认是 /etc/resolv.conf。可是 resolv.conf 在每次树莓派重启后就会被系统重置,所以咱们指定 resolve-file 文件 strict-order:表示严格按照 resolv-file 文件中的顺序从上到下进行DNS解析 listen-address:定义 dnsmasq 监听的地址,默认是监控本机的全部网卡上。为使局域网其余设备得以使用须要加上树莓派的局域网 ip cache-size:缓存条数 address:自定义域名解析的 ip 地址,以 pi.com 这个域名为例。也能够在其余文件中配置,配置文件放在 /etc/dnsmasq.d/ 中便可。例如能够在 /etc/dnsmasq.d/ 下新建文件test.conf,加入该规则,效果等同
编辑 my_dns.conf,命令行以下:网站
sudo nano /etc/my_dns.conf
粘贴以下内容:google
nameserver 127.0.0.1 nameserver 119.29.29.29 nameserver 182.254.116.116
ctrl+o 保存,以后 回车 确认,而后 ctrl+x 退出。命令行
附注,各大 dns(推荐 DNSpod):rest
114 dns: 114.114.114.114 114.114.115.115 阿里 dns: 223.5.5.5 223.6.6.6 DNSpod: 119.29.29.29 182.254.116.116
参考资料:https://www.v2ex.com/t/250719
dnsmasq 会优先检测 hosts 文件,并经过其解析 ip,咱们能够经过修改树莓派 hosts 文件实现拦截广告的需求和其余的一些需求。
在用户目录(/home/pi)创建 hosts 文件夹,在文件夹内放置一个 hosts.sh 脚本,修改文件权限:
cd ~ mkdir hosts cd hosts touch hosts.sh sudo chmod 777 hosts.sh
以后编辑文件,命令行以下:
nano hosts.sh
粘贴以下内容:
#!/bin/sh cd /home/pi/hosts/ echo "***下载 g hosts 文件***" wget --no-check-certificate https://raw.githubusercontent.com/googlehosts/hosts/master/hosts-files/hosts -O hosts_g.txt; echo "***下载 ad hosts 文件***" wget --no-check-certificate https://raw.githubusercontent.com/vokins/yhosts/master/hosts -O hosts_ad.txt; echo "***合并 hosts 文件***" cat hosts_g.txt hosts_ad.txt > hosts.txt echo "***复制 hosts 文件***" sudo cp hosts.txt /etc/hosts echo "***hosts 文件更新完成"
ctrl+o 保存,以后 回车 确认,而后 ctrl+x 退出。
编辑完成以后运行一下,命令行以下:
sudo sh hosts.sh
设置定时执行更新 hosts 脚本,命令行以下:
sudo crontab -e
添加以下内容至文件末行(天天三点半执行一次):
30 3 * * * sh /home/pi/hosts/hosts.sh
sudo service dnsmasq restart
sudo service dnsmasq status
能够经过 dig 一下相关网址来测试 dns 是否生效。
若是未安装 dnsutils,则经过以下命令安装:
sudo apt-get install dnsutils
以后能够经过以下命令行简单测试:
dig pi.com
能够只在设备上单独设置,以下:
macOS:
打开网络设置-高级-dns,配置为树莓派 ip 便可。
Windows:
控制面板-网络和Internet项-查看网络状态和任务-更改适配器设置-右键正在使用的本地链接-属性-双击Internet协议4(TCP/IPV4),将内容填写至相关部分便可。
在这里,建议在路由器配置,即配置路由器 LAN 口的 DNS 为树莓派 ip,这样便无需单独为设备配置。
例如:华硕路由器(RT-AC68U),设置 内部网络-DHCP 服务器-DNS Server 1 为树莓派 ip,以后应用便可,其余设备大同小异。
小无相功是小说《天龙八部》中「逍遥派」的一门内功,讲究不着形相,无迹可寻,熟悉后再了解其余武功招式即可依仗威力习得,甚至青出于蓝而胜于蓝。而树莓派形似小无相功,同具无限可能,了解一些基础即可轻松上手,去探寻其余更多未知。所以,系列以此为题,带来一系列树莓派相关的教程,同时也是对我的长期折腾树莓派以来的一个归档整理。
注:本做品采用知识共享署名-非商业性使用-禁止演绎 3.0 未本地化版本许可协议进行许可。