这篇文章算是上一篇文章的完善,教你如何将 ChinaDNS 与 DNSMasq 结合起来用,使其更加稳定并且可以支持 TCP 查询
Head Pic: 「チャンのエリ」/「はれんちとめこ」[pixiv]
ChinaDNS + DNSMasq
之前一篇文章讲到了如何搭建 ChinaDNS 以及关于 DNS 污染现象的详细说明,但是单纯使用 ChinaDNS 可能会不稳定,并且只支持通过UDP
的53
端口进行查询
因此,我们最好是使用 DNSMasq 作为主 DNS 服务端,将 ChinaDNS 作为 DNSMasq 的上游 DNS
以下部署过程在我两篇文章里独有讲到,但是这里会对某些步骤稍作修改,想了解关于 DNSMasq 和 ChinaDNS 的更多内容可以看我在文章末尾留的两篇文章
ChinaDNS
1. 下载并编译
- 如果你的系统中没有
make
和gcc
就需要先安装1
2
3
4# Ubuntu / Debian apt-get install -y make gcc # CentOS yum install -y make gcc
- 下载 ChinaDNS 源码并解压编译
1
2
3
4
5
6cd /root wget --no-check-certificate https://github.com/shadowsocks/ChinaDNS/releases/download/1.3.2/chinadns-1.3.2.tar.gz tar -zxvf chinadns-1.3.2.tar.gz mv chinadns-1.3.2 chinadns cd chinadns ./configure && make
- 更新 chnrouter
1
2# In /root/chinadns curl 'http://ftp.apnic.net/apnic/stats/apnic/delegated-apnic-latest' | grep ipv4 | grep CN | awk -F\| '{ printf("%s/%d\n", $4, 32-log($5)/log(2)) }' > chnroute.txt
2. 配置 supervisor 守护进程
防止 ChinaDNS 进程挂掉
如果你的系统中已经有 supervisor,那么忽略安装步骤,酌情参考除了安装之外的配置步骤
- 安装
1
2
3
4# python2 pip install supervisord # python3 pip install git+https://github.com/Supervisor/supervisor
- 初始化并修改配置文件
此处和原先不一样的一点:让 ChinaDNS 在8053
端口(或者其他非53
端口)监听,因为我们要让它做 DNSMasq 的上游 DNS1
2
3
4
5
6echo_supervisord_conf > /etc/supervisord.conf echo "[program:chinadns] command=/root/chinadns/src/chinadns -p 8053 -m -c /root/chinadns/chnroute.txt -s 114.114.114.114,208.67.222.222:443 user = root autostart = true autorestart = true" >> /etc/supervisord.conf
- 添加 supervisor 开机自启
1
2
3echo "supervisord -c /etc/supervisord.conf" >> /etc/rc.local # 执行此命令以防系统没有权限执行开机自启脚本(by youngerzhong) chmod +x /etc/rc.local
之后查看
/etc/rc.local
文件,如果有exit 0
这行,就把它移动到文件的最后一行,即保证我们上面添加的这句在exit 0
前面 -
启动 supervisor
1supervisord -c /etc/supervisord.conf
然后查看程序运行状态
1supervisorctl status
如果有输出 chinadns 的运行状态
RUNNING
就说明成功了此时可以用
dig
命令检查一下看 ChinaDNS 是否有正常运作1dig www.pixiv.net @127.0.0.1 -p 8053
DNSMasq
如果你已经有 DNSMasq,那么忽略安装步骤,酌情参考除了安装之外的配置步骤
1. 安装
Ubuntu / Debian
1apt-get install dnsmasq
CentOS
由于 CentOS 的yum
安装的 DNSmasq 版本比较旧,因此我们可以先下载最新版编译好,用yum
安装完之后再替换掉程序。
先从 http://www.thekelleys.org.uk/dnsmasq/ 找到你想要的 DNSmasq 版本的源码压缩包的下载地址,例如我选择的是我写这篇文章时的最新版dnsmasq-2.79.tar.gz
。
下载对应的源码压缩包并解压
1
2
3cd /root
wget http://www.thekelleys.org.uk/dnsmasq/dnsmasq-2.79.tar.gz
tar xf dnsmasq-2.79.tar.gz
编译,源码 make 不带 etc 等
1
2cd dnsmasq-2.79
make V=s
然后用 yum 安装 DNSmasq
1yum install dnsmasq
yum 安装的是2.4.8
版本,然后我们再用我们编译好的最新版本替换
1yes | cp -f ./src/dnsmasq /usr/sbin/dnsmasq
这时可以查看 DNSmasq 的版本检验一下
1dnsmasq -v
看一下版本号,应该就是我们编译好的版本了
2. 配置
编辑/etc/dnsmasq.conf
文件,将下面提到的配置项解除注释并进行更改
1
2
3
4
5
6
7
8
9
10
11
12# 指定监听 53 端口
port=53
# 禁止 DNSMasq 使用 resolv.conf
no-resolv
no-poll
# 指定监听IP,将 x.x.x.x 换成你的 eth0 网卡IP(用 ifconfig 命令查看)
listen-address=127.0.0.1,x.x.x.x
# 指定额外配置文件夹
conf-dir=/etc/dnsmasq.d/
如果你比较懒不想找而且只需要用 DNSMasq 做到本文所述功能,也可以直接
(注意替换x.x.x.x
)
1
2
3
4
5echo "port=53
no-resolv
no-poll
listen-address=127.0.0.1,x.x.x.x
conf-dir=/etc/dnsmasq.d/" > /etc/dnsmasq.conf
然后运行以下命令写入配置以将 ChinaDNS 作为上游 DNS
1echo "server=127.0.0.1#8053" > /etc/dnsmasq.d/chinadns.conf
重启 DNSMasq
1/etc/init.d/dnsmasq restart
3. 开放安全组/防火墙端口
这里只是特别提醒一下记得开放,特别是部分 IDC 是有“安全组”的,记得开放53
端口的 TCP 和 UDP
其余的iptables
操作这里就不教了,因为一般都是全开放,或者去百度一下
相关文章
版权声明:本文为原创文章,版权归 神代綺凜 所有。
本文链接:https://moe.best/tutorial/chinadns-plus-dnsmasq.html
所有原创文章采用 知识共享署名-非商业性使用 4.0 国际许可协议 进行许可。
您可以自由的转载和修改,但请务必注明文章来源并且不可用于商业目的。