一个本地DNS服务器,获取最快的网站IP,获得最佳上网体验。
|
|
3 роки тому | |
|---|---|---|
| .github | 4 роки тому | |
| doc | 5 роки тому | |
| etc | 3 роки тому | |
| package | 3 роки тому | |
| src | 3 роки тому | |
| systemd | 3 роки тому | |
| .clang-format | 5 роки тому | |
| .gitignore | 4 роки тому | |
| Dockerfile | 3 роки тому | |
| LICENSE | 5 роки тому | |
| Makefile | 5 роки тому | |
| ReadMe.md | 3 роки тому | |
| ReadMe_en.md | 3 роки тому |
SmartDNS 是一个运行在本地的 DNS 服务器,它接受来自本地客户端的 DNS 查询请求,然后从多个上游 DNS 服务器获取 DNS 查询结果,并将访问速度最快的结果返回给客户端,以此提高网络访问速度。
SmartDNS 同时支持指定特定域名 IP 地址,并高性匹配,可达到过滤广告的效果。
与 DNSmasq 的 all-servers 不同,SmartDNS 返回的是访问速度最快的解析结果。详细差异请看常见问题。
支持树莓派、OpenWrt、华硕路由器原生固件和 Windows 系统等。
阿里 DNS
使用阿里 DNS 查询百度IP,并检测结果。
$ nslookup www.baidu.com 223.5.5.5
Server: 223.5.5.5
Address: 223.5.5.5#53
Non-authoritative answer:
www.baidu.com canonical name = www.a.shifen.com.
Name: www.a.shifen.com
Address: 180.97.33.108
Name: www.a.shifen.com
Address: 180.97.33.107
$ ping 180.97.33.107 -c 2
PING 180.97.33.107 (180.97.33.107) 56(84) bytes of data.
64 bytes from 180.97.33.107: icmp_seq=1 ttl=55 time=24.3 ms
64 bytes from 180.97.33.107: icmp_seq=2 ttl=55 time=24.2 ms
--- 180.97.33.107 ping statistics ---
2 packets transmitted, 2 received, 0% packet loss, time 1001ms
rtt min/avg/max/mdev = 24.275/24.327/24.380/0.164 ms
pi@raspberrypi:~/code/smartdns_build $ ping 180.97.33.108 -c 2
PING 180.97.33.108 (180.97.33.108) 56(84) bytes of data.
64 bytes from 180.97.33.108: icmp_seq=1 ttl=55 time=31.1 ms
64 bytes from 180.97.33.108: icmp_seq=2 ttl=55 time=31.0 ms
--- 180.97.33.108 ping statistics ---
2 packets transmitted, 2 received, 0% packet loss, time 1001ms
rtt min/avg/max/mdev = 31.014/31.094/31.175/0.193 ms
SmartDNS
使用 SmartDNS 查询百度 IP,并检测结果。
$ nslookup www.baidu.com
Server: 192.168.1.1
Address: 192.168.1.1#53
Non-authoritative answer:
www.baidu.com canonical name = www.a.shifen.com.
Name: www.a.shifen.com
Address: 14.215.177.39
$ ping 14.215.177.39 -c 2
PING 14.215.177.39 (14.215.177.39) 56(84) bytes of data.
64 bytes from 14.215.177.39: icmp_seq=1 ttl=56 time=6.31 ms
64 bytes from 14.215.177.39: icmp_seq=2 ttl=56 time=5.95 ms
--- 14.215.177.39 ping statistics ---
2 packets transmitted, 2 received, 0% packet loss, time 1001ms
rtt min/avg/max/mdev = 5.954/6.133/6.313/0.195 ms
从对比看出,SmartDNS 找到了访问 www.baidu.com 最快的 IP 地址,比阿里 DNS 速度快了 5 倍。
多 DNS 上游服务器
支持配置多个上游 DNS 服务器,并同时进行查询,即使其中有 DNS 服务器异常,也不会影响查询。
返回最快 IP 地址
支持从域名所属 IP 地址列表中查找到访问速度最快的 IP 地址,并返回给客户端,提高网络访问速度。
支持多种查询协议
支持 UDP、TCP、TLS 和 HTTPS 查询,以及非 53 端口查询。
特定域名 IP 地址指定
支持指定域名的 IP 地址,达到广告过滤效果、避免恶意网站的效果。
域名高性能后缀匹配
支持域名后缀匹配模式,简化过滤配置,过滤 20 万条记录时间 < 1ms。
域名分流
支持域名分流,不同类型的域名向不同的 DNS 服务器查询。
Windows / Linux 多平台支持
支持标准 Linux 系统(树莓派)、OpenWrt 系统各种固件和华硕路由器原生固件。同时还支持 WSL(Windows Subsystem for Linux,适用于 Linux 的 Windows 子系统)。
支持 IPv4、IPv6 双栈
支持 IPv4 和 IPV 6网络,支持查询 A 和 AAAA 记录,支持双栈 IP 速度优化,并支持完全禁用 IPv6 AAAA 解析。
高性能、占用资源少
多线程异步 IO 模式,cache 缓存查询结果。
下载对应系统或固件版本的 SmartDNS 安装包,对应关系如下。
| 支持系统(架构) | 安装包 | 支持说明 |
|---|---|---|
| 标准 Linux 系统(ARM) | smartdns.1.yyyy.MM.dd-REL.arm-debian-all.deb | ARM 的树莓派 Raspbian Stretch 和 Debian 9 系统 |
| 标准 Linux 系统(ARM64) | smartdns.1.yyyy.MM.dd-REL.aarch64-debian-all.deb | ARM64 的 Debian Stretch 和 Debian 9 系统 |
| 标准 Linux 系统(x86_64) | smartdns.1.yyyy.MM.dd-REL.x86_64-linux-all.tar.gz | 64 位 Linux 系统 |
| 标准 Linux 系统(x86) | smartdns.1.yyyy.MM.dd-REL.x86-linux-all.tar.gz | 32 位 Linux 系统 |
| WSL | smartdns.1.yyyy.MM.dd-REL.x86_64-linux-all.tar.gz | WSL |
| Optware | smartdns.1.yyyy.MM.dd-REL.mips-optware-all.ipk | MIPS 大端架构的 Optware 系统 |
| Optware(MIPS Little Endian) | smartdns.1.yyyy.MM.dd-REL.mipsel-optware-all.ipk | MIPS 小端架构的 Optware 系统 |
| Optware(ARM) | smartdns.1.yyyy.MM.dd-REL.arm-optware-all.ipk | ARM 小端架构的 Optware 系统 |
| OpenWrt(MIPS) | smartdns.1.yyyy.MM.dd-REL.mips-openwrt-all.ipk | MIPS 大端架构的 OpenWrt 系统 |
| OpenWrt(MIPS Little Endian) | smartdns.1.yyyy.MM.dd-REL.mipsel-openwrt-all.ipk | MIPS 小端架构的 OpenWrt 系统 |
| OpenWrt(ARM) | smartdns.1.yyyy.MM.dd-REL.arm-openwrt-all.ipk | ARM 小端架构的 OpenWrt 系统 |
| OpenWrt LuCI | luci-app-smartdns.1.yyyy.MM.dd-REL.all.ipk | OpenWrt 管理界面 |
| OpenWrt LuCI | luci-app-smartdns.1.yyyy.MM.dd-REL.all-luci-compat-all.ipk | OpenWrt 管理界面、OpenWrt 18.xx 及之前版本 |
请注意:
Release 释出的软件包采取静态编译,无外部依赖,但体积大。若需要小体积软件包,请自行编译或从 OpenWrt / Entware 仓库获取。
静态编译的软件包未强制判断 CPU 架构,安装不正确的软件包将会导致服务无法启动,请确保正确安装对应的版本。
下载配套安装包,并上传到 Linux 系统中。
标准 Linux 系统(X86 / X86_64)请执行如下命令安装:
$ tar zxf smartdns.1.yyyy.MM.dd-REL.x86_64-linux-all.tar.gz
$ cd smartdns
$ chmod +x ./install
$ ./install -i
树莓派或其他 Debian 系系统(ARM / ARM64)请执行如下命令安装:
# dpkg -i smartdns.1.yyyy.MM.dd-REL.arm-debian-all.deb
修改配置
安装完成后,可配置 SmartDNS 的上游服务器信息。
一般情况下,只需要增加 server[IP]:port 和 server-tcp[IP]:port 配置项。
请尽可能配置多个上游 DNS 服务器,包括国内外的服务器。
具体配置参数请参考配置文件说明。
# vi /etc/smartdns/smartdns.conf
启动服务
# systemctl enable smartdns
# systemctl start smartdns
将 DNS 请求转发到 SmartDNS 解析
修改本地路由器的 DNS 服务器,将 DNS 服务器配置为 SmartDNS。
检测服务是否配置成功
执行
$ nslookup -querytype=ptr smartdns
查看命令结果中的 name 是否为 smartdns 或你的主机名,如果是则表示生效
$ nslookup -querytype=ptr smartdns
Server: 192.168.1.1
Address: 192.168.1.1#53
Non-authoritative answer:
smartdns name = smartdns.
安装
将软件包(使用 WinSCP 等)上传到路由器的 /root 目录,执行如下命令安装
# opkg install smartdns.1.yyyy.MM.dd-REL.xxxx.ipk
# opkg install luci-app-smartdns.1.yyyy.MM.dd-REL.all.ipk
luci-app-smartdns.1.yyyy.MM.dd-REL.all-luci-compat-all.ipk。修改配置
登录 OpenWrt 管理页面,打开 Services -> SmartDNS 进行配置。
Upstream Servers 增加上游 DNS 服务器配置,建议配置多个国内外 DNS 服务器。Domain Address 指定特定域名的 IP 地址,可用于广告屏蔽。启用服务
SmartDNS 服务生效方法有两种,一种是直接作为主 DNS 服务,另一种是作为 DNSmasq 的上游。 默认情况下,SmartDNS 采用第一种方式。如下两种方式根据需求选择即可。
方法一:作为主 DNS 服务(默认方案)
登录 OpenWrt 管理界面,点击 Services -> SmartDNS -> redirect,选择 重定向 53 端口到 SmartDNS启用 53 端口转发。
执行
$ nslookup -querytype=ptr smartdns
查看命令结果中的 name 是否为 smartdns 或你的主机名,如果是则表示生效
$ nslookup -querytype=ptr smartdns
Server: 192.168.1.1
Address: 192.168.1.1#53
Non-authoritative answer:
smartdns name = smartdns.
界面提示重定向失败
检查 iptables 和/或 ip6tables 命令是否正确安装。
OpenWrt 15.01 系统不支持 IPv6 重定向,如网络需要支持 IPv6,请将 DNSmasq 上游改为 SmartDNS,或者将 SmartDNS 的端口改为53,并停用 DNSmasq。
LEDE 系统请安装 IPv6 的 NAT 转发驱动。点击 System -> Software,点击 Update lists 更新软件列表后,安装 ip6tables-mod-nat。
使用如下命令检查路由规则是否生效
iptables -t nat -L PREROUTING | grep REDIRECT
如转发功能不正常,请使用方法二:作为 DNSmasq 的上游。
方法二:作为 DNSmasq 的上游
登录 OpenWrt 管理界面,点击 Services -> SmartDNS -> Redirect,选择作为 DNSmasq 的上游服务器,设置 DNSmasq 的上游服务器为 SmartDNS。
检测上游服务是否配置成功
执行
$ nslookup -querytype=ptr smartdns
查看命令结果中的 name 是否为 smartdns 或你的主机名,如果是则表示生效
$ nslookup -querytype=ptr smartdns
Server: 192.168.1.1
Address: 192.168.1.1#53
Non-authoritative answer:
smartdns name = smartdns.
或执行
$ nslookup smartdns
查看命令结果是否有解析出路由器的IP地址,如果是则表示生效。
或执行
ping smartdns.
检测ping是否解析对应主机的IP地址。
启动服务
勾选配置页面中的 Enable(启用)来启动 SmartDNS。
注意:
Redirect 配置选项控制。说明: 梅林固件派生自华硕固件,理论上可以直接使用华硕配套的安装包使用。但目前未经验证,如有问题,请提交 Issue。
准备
在使用此软件时,需要确认路由器是否支持 U 盘,并准备好 U 盘一个。
启用 SSH 登录
登录管理界面,点击 系统管理 -> 系统设置,配置 Enable SSH 为 Lan Only。
SSH 登录用户名密码与管理界面相同。
下载 Download Master
在管理界面点击 USB 相关应用 -> Download Master 下载。
下载完成后,启用 Download Master,如果不需要下载功能,此时可以卸载 Download Master,但要保证卸载前 Download Master 是启用的。
安装 SmartDNS
将软件包(使用 WinSCP 等)上传到路由器的 /tmp/mnt/sda1 目录(或网上邻居复制到 sda1 共享目录),执行如下命令安装
# ipkg install smartdns.1.yyyy.MM.dd-REL.mipsbig.ipk
重启路由器使服务生效
待路由器启动后, 执行
$ nslookup -querytype=ptr smartdns
查看命令结果中的 name 是否为 smartdns 或你的主机名,如果是则表示生效
$ nslookup -querytype=ptr smartdns
Server: 192.168.1.1
Address: 192.168.1.1#53
Non-authoritative answer:
smartdns name = smartdns.
额外说明
上述过程,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
准备
在使用此软件时,需要确认路由器是否支持 U 盘,并准备好 U 盘一个。
安装 SmartDNS
将软件(使用 WinSCP 等)上传到路由器的 /tmp 目录,执行如下命令安装
# ipkg install smartdns.1.yyyy.MM.dd-REL.mipsbig.ipk
修改 SmartDNS 配置
# vi /opt/etc/smartdns/smartdns.conf
另外,如需支持 IPv6,可设置工作模式为 2,将 DNSmasq 的 DNS 服务禁用,设置 SmartDNS 为主用 DNS 服务器。将文件 /opt/etc/smartdns/smartdns-opt.conf 中的 SMARTDNS_WORKMODE 的值修改为 2
SMARTDNS_WORKMODE="2"
重启路由器使服务生效
待路由器启动后, 执行
$ nslookup -querytype=ptr smartdns
查看命令结果中的 name 是否为 smartdns 或你的主机名,如果是则表示生效
$ nslookup -querytype=ptr smartdns
Server: 192.168.1.1
Address: 192.168.1.1#53
Non-authoritative answer:
smartdns name = smartdns.
注意: 若服务没有自动启动,则需要设置 Optware / Entware 自动启动,具体方法请参考 Optware/Entware 的文档。
安装 WSL
安装 WSL 运行环境,发行版本选择 Ubuntu 系统为例。安装步骤请参考 WSL 安装说明
安装 SmartDNS
下载适用于 WSL 的安装包,并解压到如 D 盘根目录。解压后目录如下:
D:\SMARTDNS
├─etc
│ ├─default
│ ├─init.d
│ └─smartdns
├─package
│ └─windows
├─src
└─systemd
双击 D:\smartdns\package\windows 目录下的 install.bat 进行安装。要求输入密码时,请输入 WLS ubuntu 的密码。
修改配置
用记事本等打开 D:\smartdns\etc\smartdns 目录中的 smartdns.conf 配置文件配置 SmartDNS。
一般情况下,只需要增加 server [IP]:port 和 server-tcp [IP]:port 配置项,
尽可能配置多个上游DNS服务器,包括国内外的服务器。
具体配置请参考配置文件说明。
重新加载配置
双击 D:\smartdns\package\windows 目录下的 reload.bat 进行重新加载。要求输入密码时,请输入 WLS ubuntu 的密码。
将 DNS 请求转发到 SmartDNS 解析
将 Windows 的默认 DNS 服务器修改为 127.0.0.1,具体步骤参考 Windows 更改 TCP/IP 设置。
检测服务是否配置成功
执行
$ nslookup -querytype=ptr smartdns
查看命令结果中的 name 是否为 smartdns 或你的主机名,如果是则表示生效
$ nslookup -querytype=ptr smartdns
Server: 192.168.1.1
Address: 192.168.1.1#53
Non-authoritative answer:
smartdns name = smartdns.
| 键名 | 功能说明 | 默认值 | 可用值/要求 | 举例 |
|---|---|---|---|---|
| server-name | DNS 服务器名称 | 操作系统主机名 / smartdns | 符合主机名规格的字符串 | server-name smartdns |
| bind | DNS 监听端口号 | [::]:53 | 可绑定多个端口。 IP:PORT: 服务器 IP:端口号 [-group]: 请求时使用的 DNS 服务器组 [-no-rule-addr]:跳过 address 规则 [-no-rule-nameserver]:跳过 Nameserver 规则 [-no-rule-ipset]:跳过 ipset 规则 [-no-rule-soa]:跳过 SOA(#) 规则 [-no-dualstack-selection]:停用双栈测速 [-no-speed-check]:停用测速 [-no-cache]:停止缓存 |
bind :53 |
| bind-tcp | DNS TCP 监听端口号 | [::]:53 | 可绑定多个端口。 IP:PORT: 服务器 IP:端口号 [-group]: 请求时使用的 DNS 服务器组 [-no-rule-addr]:跳过 address 规则 [-no-rule-nameserver]:跳过 nameserver 规则 [-no-rule-ipset]:跳过 ipset 规则。 [-no-rule-soa]:跳过 SOA(#) 规则 [-no-dualstack-selection]:停用双栈测速 [-no-speed-check]:停用测速 [-no-cache]:停止缓存 |
bind-tcp :53 |
| cache-size | 域名结果缓存个数 | 512 | 大于等于 0 的数字 | cache-size 512 |
| cache-persist | 是否持久化缓存 | 自动。 当 cache-file 所在的位置有超过 128 MB 的可用空间时启用,否则禁用。 |
[yes|no] | cache-persist yes |
| cache-file | 缓存持久化文件路径 | /tmp/smartdns.cache | 合法路径字符串 | cache-file /tmp/smartdns.cache |
| tcp-idle-time | TCP 链接空闲超时时间 | 120 | 大于等于 0 的数字 | tcp-idle-time 120 |
| 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 |
| rr-ttl-reply-max | 允许返回给客户端的最大 TTL 值 | 远程查询结果 | 大于 0 的数字 | rr-ttl-reply-max 60 |
| max-reply-ip-num | 允许返回给客户的最大IP数量 | IP数量 | 大于 0 的数字 | max-reply-ip-num 1 |
| log-level | 设置日志级别 | error | fatal、error、warn、notice、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 | 大于等于 0 的数字 | log-num 2 |
| audit-enable | 设置审计启用 | no | [yes|no] | audit-enable yes |
| audit-file | 审计文件路径 | /var/log/smartdns-audit.log | 合法路径字符串 | audit-file /var/log/smartdns-audit.log |
| audit-size | 审计大小 | 128K | 数字 + K、M 或 G | audit-size 128K |
| audit-num | 审计归档个数 | 2 | 大于等于 0 的数字 | audit-num 2 |
| conf-file | 附加配置文件 | 无 | 合法路径字符串 | conf-file /etc/smartdns/smartdns.more.conf |
| server | 上游 UDP DNS | 无 | 可重复。 [ip][:port]:服务器 IP:端口(可选) [-blacklist-ip]:配置 IP 过滤结果。 [-whitelist-ip]:指定仅接受参数中配置的 IP 范围 [-group [group] ...]:DNS 服务器所属组,比如 office 和 foreign,和 nameserver 配套使用 [-exclude-default-group]:将 DNS 服务器从默认组中排除 |
server 8.8.8.8:53 -blacklist-ip -group g1 |
| server-tcp | 上游 TCP DNS | 无 | 可重复。 [ip][:port]:服务器 IP:端口(可选) [-blacklist-ip]:配置 IP 过滤结果 [-whitelist-ip]:指定仅接受参数中配置的 IP 范围。 [-group [group] ...]:DNS 服务器所属组,比如 office 和 foreign,和 nameserver 配套使用 [-exclude-default-group]:将 DNS 服务器从默认组中排除 |
server-tcp 8.8.8.8:53 |
| server-tls | 上游 TLS DNS | 无 | 可重复。 [ip][:port]:服务器 IP:端口(可选) [-spki-pin [sha256-pin]]:TLS 合法性校验 SPKI 值,base64 编码的 sha256 SPKI pin 值 [-host-name]:TLS SNI 名称 [-tls-host-verify]:TLS 证书主机名校验 [-no-check-certificate]:跳过证书校验 [-blacklist-ip]:配置 IP 过滤结果 [-whitelist-ip]:仅接受参数中配置的 IP 范围 [-group [group] ...]:DNS 服务器所属组,比如 office 和 foreign,和 nameserver 配套使用 [-exclude-default-group]:将 DNS 服务器从默认组中排除 |
server-tls 8.8.8.8:853 |
| server-https | 上游 HTTPS DNS | 无 | 可重复。 https://[host][:port]/path:服务器 IP:端口(可选) [-spki-pin [sha256-pin]]:TLS 合法性校验 SPKI 值,base64 编码的 sha256 SPKI pin 值 [-host-name]:TLS SNI 名称 [-http-host]:http 协议头主机名 [-tls-host-verify]:TLS 证书主机名校验 [-no-check-certificate]:跳过证书校验 [-blacklist-ip]:配置 IP 过滤结果 [-whitelist-ip]:仅接受参数中配置的 IP 范围。 [-group [group] ...]:DNS 服务器所属组,比如 office 和 foreign,和 nameserver 配套使用 [-exclude-default-group]:将 DNS 服务器从默认组中排除 |
server-https https://cloudflare-dns.com/dns-query |
| speed-check-mode | 测速模式选择 | 无 | [ping|tcp:[80]|none] | speed-check-mode ping,tcp:80,tcp:443 |
| address | 指定域名 IP 地址 | 无 | address /domain/[ip|-|-4|-6|#|#4|#6] - 表示忽略 # 表示返回 SOA 4 表示 IPv4 6 表示 IPv6 |
address /www.example.com/1.2.3.4 |
| nameserver | 指定域名使用 server 组解析 | 无 | nameserver /domain/[group|-], group 为组名,- 表示忽略此规则,配套 server 中的 -group 参数使用 | nameserver /www.example.com/office |
| ipset | 域名 ipset | 无 | ipset /domain/[ipset|-|#[4|6]:[ipset|-][,#[4|6]:[ipset|-]]],-表示忽略 | ipset /www.example.com/#4:dns4,#6:- |
| ipset-timeout | 设置 ipset 超时功能启用 | 自动 | [yes] | ipset-timeout yes |
| domain-rules | 设置域名规则 | 无 | domain-rules /domain/ [-rules...] [-c|-speed-check-mode]:测速模式,参考 speed-check-mode 配置 [-a|-address]:参考 address 配置 [-n|-nameserver]:参考 nameserver 配置 [-p|-ipset]:参考ipset配置 [-d|-dualstack-ip-selection]:参考 dualstack-ip-selection |
domain-rules /www.example.com/ -speed-check-mode none |
| bogus-nxdomain | 假冒 IP 地址过滤 | 无 | [ip/subnet],可重复 | bogus-nxdomain 1.2.3.4/16 |
| ignore-ip | 忽略 IP 地址 | 无 | [ip/subnet],可重复 | ignore-ip 1.2.3.4/16 |
| whitelist-ip | 白名单 IP 地址 | 无 | [ip/subnet],可重复 | whitelist-ip 1.2.3.4/16 |
| blacklist-ip | 黑名单 IP 地址 | 无 | [ip/subnet],可重复 | blacklist-ip 1.2.3.4/16 |
| force-AAAA-SOA | 强制 AAAA 地址返回 SOA | no | [yes|no] | force-AAAA-SOA yes |
| force-qtype-SOA | 强制指定 qtype 返回 SOA | qtype id | [ | ...] | force-qtype-SOA 65 28 |
| prefetch-domain | 域名预先获取功能 | no | [yes|no] | prefetch-domain yes |
| dnsmasq-lease-file | 支持读取dnsmasq dhcp文件解析本地主机名功能 | 无 | dnsmasq dhcp lease文件路径 | dnsmasq-lease-file /var/lib/misc/dnsmasq.leases |
| serve-expired | 过期缓存服务功能 | yes | [yes|no],开启此功能后,如果有请求时尝试回应 TTL 为 0 的过期记录,并发查询记录,以避免查询等待 | |
| serve-expired-ttl | 过期缓存服务最长超时时间 | 0 | 秒,0 表示停用超时,大于 0 表示指定的超时的秒数 | serve-expired-ttl 0 |
| serve-expired-reply-ttl | 回应的过期缓存 TTL | 5 | 秒,0 表示停用超时,大于 0 表示指定的超时的秒数 | serve-expired-reply-ttl 30 |
| dualstack-ip-selection | 双栈 IP 优选 | yes | [yes|no] | dualstack-ip-selection yes |
| dualstack-ip-selection-threshold | 双栈 IP 优选阈值 | 15ms | 单位为毫秒(ms) | dualstack-ip-selection-threshold [0-1000] |
| ca-file | 证书文件 | /etc/ssl/certs/ca-certificates.crt | 合法路径字符串 | ca-file /etc/ssl/certs/ca-certificates.crt |
| ca-path | 证书文件路径 | /etc/ssl/certs | 合法路径字符串 | ca-path /etc/ssl/certs |