Files
smartdns/ReadMe.md
2018-07-22 19:16:24 +08:00

8.4 KiB
Executable File
Raw Blame History

SmartDNS

SmartDNS是一个运行在本地的DNS服务器SmartDNS接受本地客户端的DNS查询请求从多个上游DNS服务器获取DNS查询结果并将访问速度最快的结果返回个客户端避免DNS污染提高网络访问速度。 同时支持指定特定域名IP地址并高性匹配达到过滤广告的效果。

支持树莓派openwrt华硕路由器等设备。

特性

  1. 多DNS上游服务器
    支持配置多个上游DNS服务器并同时进行查询即使其中有DNS服务器异常也不会影响查询。

  2. 返回最快IP地址
    支持从域名所属IP地址列表中查找到访问速度最快的IP地址并返回给客户端避免DNS污染提高网络访问速度。

  3. 支持非标准端口
    支持非53端口查询支持TCP查询有效避免DNS污染。

  4. 特定域名IP地址指定
    支持指定域名的IP地址达到广告过滤效果避免恶意网站的效果。

  5. 域名高性能后缀匹配
    支持域名后缀匹配模式简化过滤配置过滤20万条记录时间<1ms

  6. Linux多平台支持
    支持标准Linux系统树莓派openwrt系统各种固件华硕路由器原生固件。

  7. 支持IPV4, IPV6双栈
    支持IPV4IPV6网络支持查询A, AAAA记录。

  8. 高性能,占用资源少
    多线程异步IO模式cache缓存查询结果。

架构

Architecture

  1. SmartDNS接收本地网络设备的DNS查询请求如PC手机的查询请求。
  2. SmartDNS将查询请求发送到多个上游DNS服务器可采用标准UDP查询非标准端口UDP查询及TCP查询。
  3. 上游DNS服务器返回域名对应的Server IP地址列表。SmartDNS检测与本地网络访问速度最快的Server IP。
  4. 将访问速度最快的Server IP返回给本地客户端。

使用

下载配套安装包

下载配套版本的SmartDNS安装包对应安装包配套关系如下。

系统 安装包 说明
标准Linux系统(树莓派) smartdns.xxxxxxxx.armhf.deb 支持树莓派Raspbian stretchDebian 9系统。
华硕原生固件(optware) smartdns.xxxxxxx.mipsbig.ipk 支持MIPS大端架构的系统如RT-AC55U, RT-AC66U.
华硕原生固件(optware) smartdns.xxxxxxx.mipsel.ipk 支持MIPS小端架构的系统如RT-AC68U。
openwrt 15.01 smartdns.xxxxxxxx.ar71xx.ipk 支持AR71XX MIPS系统。
openwrt 15.01 smartdns.xxxxxxxx.ramips.ipk 支持MT7620系统
openwrt LEDE smartdns.2xxxxxxxx.mips_24kc.ipk 支持AR71XX MIPS系统。
openwrt LEDE smartdns.xxxxxxxx.mipsel_24kc.ipk 支持
openwrt LUCI luci-app-smartdns.xxxxxxxxx.xxxx.all.ipk openwrt管理统一界面

此处下载

标准Linux系统安装树莓派

  1. 安装 下载配套安装包smartdns.xxxxxxxx.armhf.deb并上传到Linux系统中。 执行如下命令安装
dpkg -i smartdns.xxxxxxxx.armhf.deb
  1. 修改配置 安装完成后可配置smartdns的上游服务器信息。具体配置参数参考配置参数说明。
    一般情况下,只需要增加server [IP]:port, server-tcp [IP]:port配置项
vi /etc/smartdns/smartdns.conf
  1. 启动服务
systemctl enable smartdns
systemctl start smartdns
  1. 将DNS请求转发的SmartDNS解析。
    修改本地路由器的DNS服务器将DNS服务器配置为SmartDNS。
  • 登录到本地网络的路由器中配置树莓派分配静态IP地址。
  • 修改WAN口或者DHCP DNS为树莓派IP地址。
    注意:
    I. 每款路由器配置方法不尽相同,请百度搜索相关的配置方法。
    II. 华为等路由器可能不支持配置DNS为本地IP请修改PC端手机端DNS服务器为树莓派IP。
  1. 检测服务是否配置成功。
    使用nslookup查询域名看命令结果中的服务器项目是否显示为Linux主机名如raspberry则表示生效
C:\Users\meikechong>nslookup www.baidu.com  
服务器:  raspberry  
Address:  192.168.1.1  
  
非权威应答:  
名称:    www.a.shifen.com  
Address:  14.215.177.39  
Aliases:  www.baidu.com  

openwrt/LEDE

  1. 安装
    将软件使用winscp上传到路由器的/root目录执行如下命令安装
opkg install smartdns.xxxxxxxx.xxxx.ipk
opkg install luci-app-smartdns.xxxxxxxx.xxxx.all.ipk
  1. 修改配置
    登陆openwrt管理页面打开Services->SmartDNS进行配置。
  • 在Upstream Servers增加上游DNS服务器配置。
  • 在Domain Address指定特定域名的IP地址可用于广告屏蔽。
  1. 启动服务
    勾选配置页面中的Enable(启用)来启动SmartDNS

华硕路由器原生固件

  1. 准备
    在使用此软件时需要确认路由器是否支持U盘并准备好U盘一个。

  2. 启用SSH登录
    登录管理界面,点击系统管理->点击系统设置,配置Enable SSHLan Only
    SSH登录用户名密码与管理界面相同。

  3. 下载Download Master 在管理界面点击USB相关应用->点击Download Master下载。
    下载完成后,启用Download Master,如果不需要下载功能,此处可以卸载Download Master但要保证卸载前Download Master是启用的。

  4. 安装SmartDNS 将软件使用winscp上传到路由器的/tmp/mnt/sda1目录。或网上邻居复制到sda1共享目录

ipkg install smartdns.xxxxxxx.mipsbig.ipk
  1. 重启路由器生效服务 待路由器启动后使用nslookup查询域名看命令结果中的服务器项目是否显示为smartdns如显示smartdns则表示生效
C:\Users\meikechong>nslookup www.baidu.com  
服务器:  smartdns  
Address:  192.168.1.1  
  
非权威应答:  
名称:    www.a.shifen.com  
Address:  14.215.177.39  
Aliases:  www.baidu.com  
  1. 额外说明 上述过程smartdns将安装到U盘根目录采用optware的模式运行。 其目录结构如下: 此处仅列出smartdns相关文件
U盘
 └── asusware.mipsbig
          ├── bin
          ├── etc
          |    ├── smartdns 
          |    |     └── smartdns.conf
          |    └── init.d
          |          └── S50smartdns         
          ├── lib
          ├── sbin
          ├── usr
          |    └── sbin
          |          └── smartdns     
          ....

如要修改配置可以ssh登录路由器使用vi命令修改

vi /opt/etc/smartdns/smartdns.conf

也可以通过网上邻居修改,网上邻居共享目录sda1看不到asusware.mipsbig目录,但可以直接在文件管理器中输入asusware.mipsbig\etc\init.d访问。

\\192.168.1.1\sda1\asusware.mipsbig\etc\init.d

配置参数

参数 功能 默认值 配置值 例子
server-name DNS服务器名称 操作系统主机名/smartdns 符合主机名规格的字符串 server-name smartdns
bind DNS监听端口号 [::]:53 IP:PORT bind 192.168.1.1:53
cache-size 域名结果缓存个数 512 数字 cache-size 512
rr-ttl 域名结果TTL 远程查询结果 大于0的数字 rr-ttl 600
rr-ttl-min 允许的最小TTL值 远程查询结果 大于0的数字 rr-ttl-min 60
rr-ttl-max 允许的最大TTL值 远程查询结果 大于0的数组 rr-ttl-max 600
log-level 设置日志级别 error error,warn,info,debug log-level error
log-file 日志文件路径 /var/log/smartdns.log 路径 log-file /var/log/smartdns.log
log-size 日志大小 128K 数字+K,M,G log-size 128K
log-num 日志归档个数 2 数字 log-num 2
server 上游UDP DNS 114.114.114.114 [ip][:port],可重复 server 8.8.8.8:53
server-tcp 上游TCP DNS [IP][:port],可重复 server-tcp 8.8.8.8:53
address 指定域名IP地址 address /domain/ip address /www.example.com/1.2.3.4

捐助

  • PayPal
    Support via PayPal

  • Alipay 支付宝
    alipay

  • Wechat 微信
    wechat

说明

目前代码未开源,后续根据情况开源。