dae/docs/en/tutorials/dae-with-opnsense.md

6.4 KiB

dae with OPNsense: Best Practices

This tutorial shows how to use dae with OPNsense in a bypass way. dae is installed on another Linux system and is connected to OPNsense via Ethernet (physical connection, Linux bridge, or SR-IOV).

Interfaces

You should assign an address for the interface between dae and OPN that is in a different subnet from OPN's LAN. If we call this interface wan_proxy, the configuration is as follows:

OPN LAN: 192.168.1.1/24
OPN wan_proxy: 192.168.2.2 Gateway Auto Detect
dae enp1s0: 192.168.2.1 Gateway 192.168.2.2

Traffic Splitting

  1. Configure the GeoIP list

    Add it in Firewall: Aliases: GeoIP Settings, refer to the OPN documentation.

  2. Configure GeoIP alias

    Add an alias named proxyip in Firewall: Aliases: Aliases, select GeoIP type, and choose China in the displayed region Asia(or your own country).

  3. Add additional IP address list (optional)

    Add an alias named proxyip_ex in Firewall: Aliases: Aliases, select URL Table type, you can add a link to an IP list maintained by others, the file content is an IP address represented by CIDR per line.

  4. Configure reserved address alias

    Add an alias named __private_network in Firewall: Aliases: Aliases, select Network type, add all reserved addresses (or only add the reserved addresses used in your network), refer to Reserved IP Addresses.

  5. Aggregate the above aliases

    Add an alias named proxyroute in Firewall: Aliases: Aliases, select Network group type, select proxyip, proxyip_ex (if any), __private_network and the system built-in __lo0_network alias, and aggregate them.

  6. Add gateway

    Add a gateway named proxy in System: Gateways: Single, select the interface wan_proxy between dae, the IP is the IP of dae, according to the interface example above, fill in 192.168.2.1 here, the priority must be lower than the default gateway, such as the default gateway set to 254, set this to 255.

  7. Traffic splitting rules

    Add a rule in Firewall: Rules: Floating, configure as follows:

    Item Configuration
    Action Pass
    Quick
    Interface LAN
    Direction in
    TCP/IP Version IPv4
    Protocol TCP/UDP
    Destination/Invert
    Destination proxyroute
    Gateway proxy

    In addition, you can exclude LAN devices through Source/Invert, so their traffic will not be passed to dae.

  8. Allow dae traffic to enter OPN

    Create a new rule in Firewall: Rules: wan_proxy, keep all defaults and save.

  9. OPN's own proxy (optional)

    If you need to route some of OPN's own traffic through the proxy, such as using Google Drive to backup configurations, it is recommended to add a static route rule in System: Routes: Configuration, set the gateway for the IP segment that needs to be proxied to proxy. It is not recommended to handle WAN traffic in floating rules, which may cause loops.

This section does not involve the content of the dae configuration file, but only gives how to configure DNS requests to pass through dae, and solutions to the common problem that the proxy is normal and the direct connection is not working. For the domain and ip modes mentioned below and how to configure dae's dns and routing rules, please refer to the dae documentation.

To use dae for transparent proxy, to make the domain name based traffic splitting rules work normally, DNS requests need to pass through dae in the domain and domain+ modes (note that the DNS server is not set to the dae address, dae does not listen to port 53). If DNS requests do not pass through dae, you need to use dae's domain++ mode (match the traffic splitting rules again based on the sniffed domain name, which is not as performant as the domain mode). If you use the domain++ mode, or do not need to split traffic based on the domain name and use the ip mode, the following configuration can be ignored.

  1. DNS forwarding configuration

    Set in Services: Unbound DNS: Query Forwarding, forward DNS requests to the specified server, such as configuring OpenDNS's 208.67.222.222. The next step requires setting a static route rule, setting the gateway of this address to dae, so do not use the DNS issued by your upstream, so that you can normally use dig or nslookup to query the DNS server issued by the upstream for testing when troubleshooting DNS problems.

  2. Static route configuration

    Add a static route rule in System: Routes: Configuration, set the network to 208.67.222.222/32, and set the gateway to proxy.

After the above configuration, DNS requests can pass through dae and be hijacked by dae for processing. The DNS server set here is not the final query server. The target server of the DNS query will be rewritten by dae according to the dns rules in the dae configuration, and then the DNS query request will be sent.

It should be noted that Unbound will append EDNS related parameters when forwarding client's DNS requests, which may result in oversized (occasionally larger than 2000) DNS responses from the upstream server, causing dae's buffer for processing udp DNS to overflow (for performance considerations, dae does not use a larger buffer, tcp's DNS will not overflow), and the final result is that the client cannot get the DNS response, or even cause dae to crash. To solve this problem, you can switch to Dnsmasq or disable EDNSSEC support in Services: Unbound DNS: General and write the following Unbound configuration, which can effectively reduce the size of the returned DNS response.

# saved as /usr/local/etc/unbound.opnsense.d/disableedns.conf
server:
    disable-edns-do: yes 

In addition, since dae does not perform snat, if the proxy is normal and the direct connection is not working [here refers to the direct in dae's routing, not the traffic that OPN does not split to dae and directly goes out of the WAN port. For example, according to the traffic splitting rules configured in the previous section, OPN will split the steam's traffic to pass through dae, dae has configured domain(geosite:steam@cn) -> direct in routing, steam cannot log in or download normally], configure nat in the system where dae is installed.

Performance Optimization

Changing the MTU value between OPN and dae from the default 1500 to 9000 (requires modifying both interfaces and the intermediate link) can achieve lower load.