dae/example.dae

170 lines
7.5 KiB
Plaintext
Raw Normal View History

2023-01-28 00:50:21 +07:00
global {
2023-02-27 12:29:42 +07:00
# tproxy port to listen on. It is NOT a HTTP/SOCKS port, and is just used by eBPF program.
2023-02-12 15:04:30 +07:00
# In normal case, you do not need to use it.
2023-01-28 00:50:21 +07:00
tproxy_port: 12345
2023-02-12 00:06:43 +07:00
# Log level: error, warn, info, debug, trace.
log_level: info
2023-01-28 00:50:21 +07:00
# Node connectivity check.
# Host of URL should have both IPv4 and IPv6 if you have double stack in local.
2023-02-13 17:26:31 +07:00
# Considering traffic consumption, it is recommended to choose a site with anycast IP and less response.
# tcp_check_url: 'http://keep-alv.google.com/generate_204'
tcp_check_url: 'http://gstatic.com/generate_204'
2023-02-12 00:06:43 +07:00
# This DNS will be used to check UDP connectivity of nodes. And if dns_upstream below contains tcp, it also be used to check
# TCP DNS connectivity of nodes.
# This DNS should have both IPv4 and IPv6 if you have double stack in local.
2023-02-09 12:42:52 +07:00
udp_check_dns: 'dns.google:53'
2023-02-12 00:06:43 +07:00
2023-01-28 14:47:43 +07:00
check_interval: 30s
2023-02-12 00:06:43 +07:00
# Group will switch node only when new_latency <= old_latency - tolerance.
check_tolerance: 50ms
2023-01-28 00:50:21 +07:00
# The LAN interface to bind. Use it if you only want to proxy LAN instead of localhost.
# Multiple interfaces split by ",".
2023-02-19 11:37:37 +07:00
#lan_interface: docker0
2023-01-30 17:13:43 +07:00
2023-02-11 12:53:43 +07:00
# The WAN interface to bind. Use it if you want to proxy localhost.
# Multiple interfaces split by ",". Use "auto" to auto detect.
wan_interface: auto
# Allow insecure TLS certificates. It is not recommended to turn it on unless you have to.
allow_insecure: false
2023-02-18 01:06:23 +07:00
# Optional values of dial_mode are:
# 1. "ip". Dial proxy using the IP from DNS directly. This allows your ipv4, ipv6 to choose the optimal path
2023-02-18 01:06:23 +07:00
# respectively, and makes the IP version requested by the application meet expectations. For example, if you
# use curl -4 ip.sb, you will request IPv4 via proxy and get a IPv4 echo. And curl -6 ip.sb will request IPv6.
# This may solve some wierd full-cone problem if your are be your node support that.
# 2. "domain". Dial proxy using the domain from sniffing. This will relieve DNS pollution problem to a great extent
2023-02-18 01:06:23 +07:00
# if have impure DNS environment. Generally, this mode brings faster proxy response time because proxy will
# re-resolve the domain in remote, thus get better IP result to connect. This policy does not impact routing.
# That is to say, domain rewrite will be after traffic split of routing and dae will not re-route it.
2023-03-13 15:49:01 +07:00
# 3. "domain+". Based on domain mode but do not check the reality of sniffed domain. It is useful for users whose
# DNS requests do not go through dae but want faster proxy response time. Notice that, if DNS requests do not
# go through dae, dae cannot split traffic by domain.
2023-03-14 17:22:00 +07:00
# 4. "domain++". Based on domain+ mode but force to re-route traffic using sniffed domain to partially recover
# domain based traffic split ability. It doesn't work for direct traffic and consumes more CPU resources.
dial_mode: domain
# Disable waiting for network before pulling subscriptions.
disable_waiting_network: false
# Automatically configure Linux kernel parameters like ip_forward and send_redirects. Check out
# https://github.com/daeuniverse/dae/blob/main/docs/getting-started/kernel-parameters.md to see what will dae do.
auto_config_kernel_parameter: true
2023-01-28 00:50:21 +07:00
}
# Subscriptions defined here will be resolved as nodes and merged as a part of the global node pool.
# Support to give the subscription a tag, and filter nodes from a given subscription in the group section.
2023-01-28 00:50:21 +07:00
subscription {
# Add your subscription links here.
2023-02-10 10:59:40 +07:00
my_sub: 'https://www.example.com/subscription/link'
another_sub: 'https://example.com/another_sub'
'https://example.com/no_tag_link'
'file://relative/path/to/mysub.sub' # Put subscription content in /etc/dae/relative/path/to/mysub.sub
2023-01-28 00:50:21 +07:00
}
# Nodes defined here will be merged as a part of the global node pool.
2023-01-28 00:50:21 +07:00
node {
# Add your node links here.
# Support socks5, http, https, ss, ssr, vmess, vless, trojan, trojan-go
2023-01-30 17:13:43 +07:00
'socks5://localhost:1080'
2023-03-07 12:30:27 +07:00
mylink: 'ss://LINK'
node1: 'vmess://LINK'
node2: 'vless://LINK'
2023-01-28 00:50:21 +07:00
}
2023-03-14 15:20:47 +07:00
# See https://github.com/daeuniverse/dae/blob/main/docs/dns.md for full examples.
2023-02-25 01:38:21 +07:00
dns {
upstream {
# Value can be scheme://host:port, where the scheme can be tcp/udp/tcp+udp.
# If host is a domain and has both IPv4 and IPv6 record, dae will automatically choose
# IPv4 or IPv6 to use according to group policy (such as min latency policy).
# Please make sure DNS traffic will go through and be forwarded by dae, which is REQUIRED for domain routing.
# If dial_mode is "ip", the upstream DNS answer SHOULD NOT be polluted, so domestic public DNS is not recommended.
alidns: 'udp://dns.alidns.com:53'
googledns: 'tcp+udp://dns.google:53'
}
routing {
2023-03-27 11:45:10 +07:00
# According to the request of dns query, decide to use which DNS upstream.
# Match rules from top to bottom.
request {
2023-03-27 11:45:10 +07:00
# fallback is also called default.
2023-03-22 11:11:11 +07:00
fallback: alidns
}
2023-03-27 11:45:10 +07:00
# According to the response of dns query, decide to accept or re-lookup using another DNS upstream.
# Match rules from top to bottom.
response {
2023-03-27 11:45:10 +07:00
# Trusted upstream. Always accept its result.
upstream(googledns) -> accept
2023-03-27 11:45:10 +07:00
# Possibly polluted, re-lookup using googledns.
!qname(geosite:cn) && ip(geoip:private) -> googledns
2023-03-27 11:45:10 +07:00
# fallback is also called default.
fallback: accept
}
2023-02-25 01:38:21 +07:00
}
}
2023-02-05 12:31:21 +07:00
# Node group (outbound).
2023-01-28 00:50:21 +07:00
group {
my_group {
2023-03-07 12:30:27 +07:00
# No filter. Use all nodes.
2023-01-28 00:50:21 +07:00
# Randomly select a node from the group for every connection.
2023-02-19 11:37:37 +07:00
#policy: random
# Select the first node from the group for every connection.
2023-02-19 11:37:37 +07:00
#policy: fixed(0)
# Select the node with min last latency from the group for every connection.
2023-02-19 11:37:37 +07:00
#policy: min
# Select the node with min moving average of latencies from the group for every connection.
policy: min_moving_avg
2023-01-28 00:50:21 +07:00
}
2023-01-31 23:02:46 +07:00
group2 {
# Filter nodes from the global node pool defined by the subscription and node section above.
2023-02-10 11:02:25 +07:00
filter: subtag(regex: '^my_', another_sub) && !name(keyword: 'ExpireAt:')
# Filter nodes from the global node pool defined by tag
#filter: name(node1, node2)
2023-01-31 23:02:46 +07:00
# Select the node with min average of the last 10 latencies from the group for every connection.
policy: min_avg10
}
2023-01-28 00:50:21 +07:00
}
2023-03-14 14:01:55 +07:00
# See https://github.com/daeuniverse/dae/blob/main/docs/routing.md for full examples.
2023-01-28 00:50:21 +07:00
routing {
2023-02-19 11:46:11 +07:00
### Preset rules.
2023-01-31 23:02:46 +07:00
2023-03-13 16:05:27 +07:00
# If you bind to WAN and set upstream (in section "dns") to a DNS service in localhost (dnsmasq, adguard, etc.),
# to avoid loops, let them "must_direct", which makes DNS requests not redirect back to dae again.
# "pname" means process name.
2023-03-22 20:54:50 +07:00
pname(dnsmasq, systemd-resolved) && l4proto(udp) && dport(53) -> must_direct
2023-02-19 11:46:11 +07:00
# Network managers in localhost should be direct to avoid false negative network connectivity check when binding to
# WAN.
2023-03-22 20:54:50 +07:00
pname(NetworkManager) -> direct
2023-02-19 11:46:11 +07:00
# Put it in the front to prevent broadcast, multicast and other packets that should be sent to the LAN from being
# forwarded by the proxy.
# "dip" means destination IP.
dip(224.0.0.0/3, 'ff00::/8') -> direct
2023-02-19 11:46:11 +07:00
# This line allows you to access private addresses directly instead of via your proxy. If you really want to access
# private addresses in your proxy host network, modify the below line.
dip(geoip:private) -> direct
2023-02-19 11:46:11 +07:00
### Write your rules below.
dip(geoip:cn) -> direct
2023-01-28 00:50:21 +07:00
domain(geosite:cn) -> direct
2023-02-11 23:53:33 +07:00
fallback: my_group
2023-01-28 00:50:21 +07:00
}