I have a raspberry pi on which I'm planning to run 2 DNS-servers, both authoritative, one on port 53, and one on port 54. What I want is all except some traffic to go to the first one, and then all traffic with a certain IP, lets say 192.168.1.0/16
to go to the second one (which will forward any DNS entries it can't find to the first server).
Currently testing on a Ubuntu VM because it's a little easier to edit files that way.
I've already found some material on the subject but it makes no sense to me (like this and this) and some of the options being used look like they're not available to me. I'm not at all familiar with iptables so most of it looks like gibberish to me.
What I'm looking for is redirecting traffic from port A to port B if it's coming from certain IP addresses and some info on what the command or config actually does.
update:
I've tried to create some rules, I have no idea what I'm doing or why it's not working. This were the commands:
iptables -t nat -A PREROUTING -s 192.168.1.0/16 -p udp --dport 53 -j DNAT --to-destination 127.0.0.1:53
iptables -t nat -A PREROUTING -p udp --dport 53 -j DNAT --to-destination 127.0.0.1:54
iptables -t nat -A PREROUTING -s 192.168.0.0/16 -p tcp --dport 53 -j DNAT --to-destination 127.0.0.1:53
iptables -t nat -A PREROUTING -p tcp --dport 53 -j DNAT --to-destination 127.0.0.1:54
The result looks like this:
root@Gelunox-Ubuntu-VM:~# iptables -t nat -L
Chain PREROUTING (policy ACCEPT)
target prot opt source destination
DNAT udp -- 192.168.0.0/16 anywhere udp dpt:domain to:127.0.0.1:53
DNAT udp -- anywhere anywhere udp dpt:domain to:127.0.0.1:54
DNAT tcp -- 192.168.0.0/16 anywhere tcp dpt:domain to:127.0.0.1:53
DNAT tcp -- anywhere anywhere tcp dpt:domain to:127.0.0.1:54