# 日志设置
log:
level: info # 日志级别。可选 "debug" "info" "warn" "error"。默认 "info"。
production: false # 纯 json 输出。
file: "/path/to/log/file" # (实验性) 记录日志到文件。默认输出至 stderr。
# 注意: 日志应由守护进程处理而不是直接写入文件。
# 此选项仅用于调试。panic 日志不会被记录,其内容仍会
# 输出至 stderr 。
# (实验性) API 入口设置
api:
http: "127.0.0.1:8080" # 在该地址启动 api 接口。
# []string, 从其他配置文件载入 plugins 插件设置。
# include 的插件会比本配置文件中的插件先初始化。
include: []
# 插件设置
plugins:
- tag: tag1 # 插件的 tag。由用户自由设定但不能重复。可省略。
type: type1 # 插件类型。详见下文。
args: # 插件参数。取决于插件类型。详见下文。
key1: value1
多功能转发器: 缓存加速,屏蔽广告。点击展开
这个配置文件
用户可以用 sequence
插件将多个插件按顺序组合,组成自己想要的运行逻辑。比如下文的配置利用 matches (匹配条件) 屏蔽广告域名。
示例中的广告列表 oisd_dbl_basic.txt 来自 oisd.nl (官网首页)。下载地址: https://dbl.oisd.nl/basic/ 。
使用 oisd 域名表仅以展示为目的。mosdns 的域名匹配器非常高效,即使载入并匹配百万域名的 oisd full 列表也不会影响匹配速度。(当然启动后会占更多内存,1w 条域名约占 1m 内存)
log:
level: info
plugins:
- tag: main
type: sequence
args:
- matches: # 如果
- qname &./oisd_dbl_basic.txt # 如果请求的域名在广告列表内。
exec: reject 3 # 执行 直接返回 NXDOMAIN(3) 屏蔽。
- exec: cache 1024 # 然后。查找 cache。
- matches: # 如果
- has_resp # 有应答了(上一步 cache 找到应答)
exec: accept # 结束。
# 上一步没有找到缓存,就会到这一步,转发至 Google 获取应答。
- exec: forward https://8.8.8.8/dns-query
# sequence 结束(被 reject,accept,或者运行到末尾)后就会返回调用者。在这个配置文件中
# 调用者是下面的服务器。服务器就会返回应答至客户端。
# 启动 udp 和 tcp 服务器。
- type: udp_server
args:
entry: main # 收到的请求会执行上面的逻辑
listen: 127.0.0.1:5533
- type: tcp_server
args:
entry: main
listen: 127.0.0.1:5533