搭建局域网 DNS - SmartDns

现在因为某个原因, 导致本地 DNS 对网络影响特别严重, 所以建议本地如果有能力可以自己搭建 DNS 服务器来进行部署.

默认的 Ubuntu 之中会默认开启 systemd-resolved.service 监听 53 端口来做本地域名解析, 所以需要将他关闭:

1
2
3
4
5
6
7
# 编辑默认服务文件
sudo vim /etc/systemd/resolved.conf

# 找到如下配置修改如下:
# DNSStubListener=no
# 之后重启下服务即可
sudo systemctl restart systemd-resolved.service

之后直接采用 SmartDns 的服务进行管理:

1
2
3
4
5
# 直接系统服务安装
sudo apt install smartdns -y

# 安装之后就是编辑下配置文件
sudo vim /etc/smartdns/smartdns.conf

需要配置文件如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
# dns server name, default is host name
# lookup 局域网配置的开放dns名称
server-name meteorcat-dns


# dns cache size
# dns 换成容量
cache-size 65536

# enable persist cache when restart
# 重启之后的持久缓存
cache-persist yes

# cache persist file
# 持久缓存保存目录
cache-file /tmp/smartdns.cache

# prefetch domain
# 开启预读域名
prefetch-domain yes

# speed check mode
# 域名测试方式
speed-check-mode ping,tcp:443,tcp:80

# force AAAA query return SOA
# 不请求IPv6数据
force-AAAA-SOA yes

# remote udp dns server list
# DNS域名UDP服务
server 9.9.9.9
server 223.6.6.6
server 119.29.29.29
server 180.76.76.76
server 218.30.118.6
server 114.114.115.115
server 210.2.4.8
server 117.50.22.22
server 101.102.103.104

# remote https dns server list
# 远程 doh 服务器
server-https https://doh.360.cn/dns-query
server-htpps https://dns.google/dns-query
server-https https://doh.opendns.com/dns-query
server-https https://dns.alidns.com/dns-query
server-https https://dns.adguard.com/dns-query
server-https https://dns.quad9.net/dns-query
server-https https://sm2.doh.pub/dns-query

这样基础配置就可以, 启动服务即可:

1
2
3
4
5
6
7
8
# 启动服务
sudo systemctl start smartdns.service

# 开机启动
sudo systemctl enable smartdns.service

# 查看是否启用监听, 没问题则标识服务启动
sudo lsof -i :53