Future Consideration Feature Request - Guest Network separate DHCP/DNS settings

Hi @TP_LINK,
I've had rock solid performance so far, and do like the Deco Labs options (although the Wifi Interference check results show 'low' then say underneath that there is significant interference), I do, however, have a feature request to put forward.
My use case:
- 3 x Deco M5s in Router mode
- Several wired and many wireless devices on the main network
- Several wireless devices on the guest network (my work devices)
- DHCP is handled by the Deco, and DNS is served by another server on the main network.
If I set the DNS to only have the DNS server, both the main and guest network use these settings. This causes the guest network to fail as it is segregated from the main network where the DNS server resides.
- Copy Link
- Subscribe
- Bookmark
- Report Inappropriate Content
You can't guarantee that the client will use DNS 2 on the traditional network.
 For me, this is a bad idea because the goal of Pi Hole is to handle 100% of traffic through it.
+1 for adding this feature.
With a Pi Hole as a DNS server, the guest network doesn't function like the LAN is isolated.
- Copy Link
- Report Inappropriate Content
- Copy Link
- Report Inappropriate Content
same issue with me, running AdGuard Home on my raspberry pi and not being abble to utilize the guest network properly
- Copy Link
- Report Inappropriate Content
Hey @TP-Link
we are several people that have the same problem i all kind of devices... I have 2 X50 that im thinking about selling because of this problem!!!
- Copy Link
- Report Inappropriate Content
- Copy Link
- Report Inappropriate Content
Please just add an exception to local network isolation, so that clients on the guest network can connect to the manual DNS IP address that I set (e.g., 192.168.1.2). This is probably the simplest way to allow a local DNS server such as PiHole to serve all clients on the network (both main and guest).
- Copy Link
- Report Inappropriate Content
OK folks, I've got a solution for this, to allow guest clients to reach dns server on main network.
 For those that are not afraid of some networking voodoo.
 (TL;DR - apply the persistant config further down).
So we know that the guest network is on another vlan (591).
 Well, the wired connections are actually trunk ports, including guest vlan traffic.
 (You can view this traffic with: `sudo tcpdump -ne|grep 'vlan 591'`).
First, set your dhcp primary dns to your server on the main network (and no secondary dns).
 Then, assuming your wired connection is on eth0 of your dns server, we can add a sub-interface on the vlan with:
sudo ip link add link eth0 name eth0.591 type vlan id 591 sudo ip link set dev eth0.591 up sudo ip addr add 10.10.10.10/32 dev eth0.591 #arbitrary ip. an ip is needed for arp responses.
This is enough to process the vlan tagged packets, and deliver them to the kernel.
 If you search on your dns server for a guest client ip, you should now see requests reaching the server.
For the responses, we'll need some routing to send them back over the guest vlan.
 But of course, the guest and main networks are on the same subnet. So destination based routing is no use.
 The only thing we have to go on, is that guest requests are coming in from the vlan interface eth0.591.
 To solve this, we can use iptables to mark dns connections from this interface:
# Mark incoming DNS requests that arrive on eth0.591 (VLAN 591) sudo iptables -t mangle -A PREROUTING -i eth0.591 -p udp --dport 53 -j MARK --set-mark 591 sudo iptables -t mangle -A PREROUTING -i eth0.591 -p tcp --dport 53 -j MARK --set-mark 591 # Save the mark to the connection tracking table (CONNMARK) sudo iptables -t mangle -A PREROUTING -i eth0.591 -p udp --dport 53 -j CONNMARK --save-mark sudo iptables -t mangle -A PREROUTING -i eth0.591 -p tcp --dport 53 -j CONNMARK --save-mark # Restore the mark on *outgoing* response packets sudo iptables -t mangle -A OUTPUT -p udp --sport 53 -j CONNMARK --restore-mark sudo iptables -t mangle -A OUTPUT -p tcp --sport 53 -j CONNMARK --restore-mark
Then route the responses using the mark (and a new table):
sudo ip rule add fwmark 0x24f lookup 591 priority 100 sudo ip route add 192.168.68.0/22 dev eth0.591 table 591 #substitute your LAN subnet here
Bosh!
 Persisting the config..
You will need:
 * netplan, using networkd renderer.
 * networkd-dispatcher service running.
Append vlan config to /etc/netplan/01-netcfg.yaml:
network:
  version: 2
  renderer: networkd
  ethernets:
    eth0:
      dhcp4: yes
  vlans:
    eth0.591:
      id: 591
      link: eth0
      addresses:
      - 10.10.10.10/32
      routes:
      - to: 192.168.68.0/22   #substitute your LAN subnet
        table: 591
        scope: link
      routing-policy:
      - from: 0.0.0.0/0
        mark: 591
        table: 591
        priority: 100
 
Create /etc/networkd-dispatcher/routable.d/90-vlan591:
#!/bin/bash [[ "$IFACE" == "eth0.591" ]] || exit 0 iptables -t mangle -A PREROUTING -i eth0.591 -p udp --dport 53 -j MARK --set-mark 591 iptables -t mangle -A PREROUTING -i eth0.591 -p tcp --dport 53 -j MARK --set-mark 591 iptables -t mangle -A PREROUTING -i eth0.591 -p udp --dport 53 -j CONNMARK --save-mark iptables -t mangle -A PREROUTING -i eth0.591 -p tcp --dport 53 -j CONNMARK --save-mark iptables -t mangle -A OUTPUT -p udp --sport 53 -j CONNMARK --restore-mark iptables -t mangle -A OUTPUT -p tcp --sport 53 -j CONNMARK --restore-mark
and make executable:
sudo chmod +x /etc/networkd-dispatcher/routable.d/90-vlan591
apply:
sudo netplan apply
- Copy Link
- Report Inappropriate Content
- Copy Link
- Report Inappropriate Content
- Copy Link
- Report Inappropriate Content
- Copy Link
- Report Inappropriate Content

Information
Helpful: 173
Views: 57213
Replies: 244
Voters 162


































































































































































