使用dingo + unbound建立自用无污染dns
为了能有一个良好的上网环境,建立一个自用无污染dns必须的,否则你可能遇到如下几种情况:
针对敏感域名的错误解析
经过查询ip归属地发现是属于facebook的ip,除非twitter和facebook已成一家。。。不然这不科学。
未注册域名存在记录
从上图可见,使用电信的当地dns(上海)查询一个未注册域名,存在A记录。然而查询这个域名的whois信息,你会得到如下结果:
显然这是电信的套路。。。下面开始正题吧。
配置google public dns反代
dingo使用的是google的httpdns,但在国内是无法访问到google的,因此需要找一台位于港澳台的服务器做一个反向代理(同时保证解析出的结果在大陆的访问速度)。
以下为nginx配置,仅供参考(仅包含反代部分)
location / {
proxy_set_header Host 'dns.google.com';
proxy_redirect off;
proxy_set_header X_FORWARDED_PROTO https;
proxy_pass https://dns.google.com;
}
编译dingo
环境准备
由于dingo使用golang编写,要编译dingo我们需要先准备好golang环境。当然你也可以到github上下载预编译好的release,即可跳过编译过程。
wget -c https://storage.googleapis.com/golang/go1.8.3.linux-amd64.tar.gz
unzip go1.8.3.linux-amd64.tar.gz
mv go /usr/local/
mkdir /usr/local/go/workspace
# 添加环境变量 (.bashrc / .zshrc等文件中, 根据你的情况选择,本文使用.bashrc)
GOROOT="/usr/local/go"
GOPATH="$GOROOT/workspace"
PATH="$GOROOT/bin:$GOPATH/bin:$PATH"
export GOROOT GOPATH PATH
source ~/.bashrc
当输入go version
后出现下面的结果,就说明环境已经准备好了。
编译dingo
git clone https://github.com/pforemski/dingo.git
cd dingo
go get https://github.com/pforemski/dingo
./build.sh linux-amd64
编译完成后会在/usr/local/go/workspace/bin
目录下出现,dingo的可执行文件。执行dingo --help
会出现dingo的参数说明:
至此dingo编译完成。
启动dingo服务
dingo启动命令:
/usr/bin/dingo -gdns:server=你的反代ip -gdns:host=你的反代域名 -gdns:sni=你的反代域名 -bind 127.0.0.1 -port 5353
如果需要后台启动,并且方便管理,可以使用supervisor或者systemd。鉴于自己对systemd还不熟,目前使用了supervisor。
安装unbound
如果没有什么特殊需求的话(比如edns-client-subnet),直接试用apt等软件包管理工具安装unbound即可。
apt-get install unbound -y
安装完成后注意修改/etc/default/unbound
文件
- RESOLVCONF_FORWARDERS=true
+ RESOLVCONF_FORWARDERS=false
配置unbound
wget ftp://FTP.INTERNIC.NET/domain/named.cache -O/etc/unbound/root.hints
unbound-control-setup # 生成unbound-control证书文件
参考配置文件,具体参数作用可以查看官方文档
# Unbound configuration file for Debian.
#
# See the unbound.conf(5) man page.
#
# See /usr/share/doc/unbound/examples/unbound.conf for a commented
# reference config file.
#
# The following line includes additional configuration files from the
# /etc/unbound/unbound.conf.d directory.
server:
num-threads: 1 # 使用cpu cores
interface: 0.0.0.0 # 监听地址
port: 53 # 监听端口
interface: ::0
so-rcvbuf: 4m
so-sndbuf: 4m
so-reuseport: yes # 多线程设置为yes
msg-cache-size: 64m
rrset-cache-size: 128m
cache-max-ttl: 3600
outgoing-num-tcp: 256
incoming-num-tcp: 1024
do-ip4: yes
do-ip6: no
do-udp: yes
do-tcp: yes
tcp-upstream: no
access-control: 127.0.0.1 allow ##
access-control: 10.0.0.0/24 allow ## ACL
access-control: 192.168.56.0/24 allow ##
root-hints: "/etc/unbound/root.hints"
hide-identity: yes
hide-version: yes
harden-glue: yes
module-config: "iterator"
unwanted-reply-threshold: 10000000
do-not-query-localhost: no
prefetch: yes
minimal-responses: no
logfile: "/var/log/unbound.log"
log-queries: yes
include: "/etc/unbound/unbound.conf.d/*.conf" # 包含unbound.conf.d目录下的conf文件
forward-zone: ##
name: "." ##
forward-addr: 127.0.0.1@5353 ## 转发请求到dingo
forward-first: no ##
remote-control: # unbound-control命令相关配置
control-enable: yes
control-interface: 127.0.0.1
control-port: 8953
control-key-file: "/etc/unbound/unbound_control.key"
control-cert-file: "/etc/unbound/unbound_control.pem"
server-key-file: "/etc/unbound/unbound_server.key"
server-cert-file: "/etc/unbound/unbound_server.pem"
配置国内站点加速
配置国内站点的解析转发到国内dns,使用到dnsmasq-china-list。
git clone https://github.com/felixonmars/dnsmasq-china-list.git
cd dnsmasq-china-list
make SERVER=119.29.29.29 unbound # 可以使用`SERVER=`修改转发dns地址,默认使用的是电信的114
cp accelerated-domains.china.unbound.conf /etc/unbound/unbound.conf.d/accelerated-domains.china.unbound.conf
systemctl restart unbound # service unbound restart
将dns修改为本地dns
Linux系统修改方法:
vim /etc/resolv.conf
nameserver 127.0.0.1
Windows的就不多说了/w\
参考资料
unbound配置及加速:
使用 Unbound 搭建更好用的 DNS 服务器
unbound配置:
Unbound documentation