Cisco DNS doctoring is a process that intercepts a DNS response packet as itÂ comse back into the network and changes the IP address in the response.
Why Would you want to do this? Well lets say you have a web server on you network, and its public IP is 126.96.36.199, and on your LAN its internal IP address is 192.168.1.100, its public DNS name, (or URL) is www.yoursite.com. When a user types www.yoursite.com into their browser, DNS will respond with the public IP of 188.8.131.52, and not the IP address thats on your LAN (192.168.1.100). The client can't send the traffic out of the firewall, 'hairpin' it though 180 degrees and send the traffic back in again. So it fails. What DNS does is look for DNS response packets that have 184.108.40.206 in then and dynamically change the ip in the packet to 192.168.1.100.
Are there any prerequisites? Only that the DNS server sending the response sends it response though the ASA, i.e. if you have your own DNS serve onsite that serves the request (without a forward lookup or a root hint). then the DNS response does not go though the ASA so it can't doctor it. This happens if you public website and your internal domain have the same name, or if your DNS server is authoritative for a domain with an IP address outside your network. To solve that problem your best bet is to setup 'Split DNS'
How to Setup DNS Doctoring
If you read the preamble you know that the DNS response needs to go though the firewall,Â and the public IP that gets resolved needs to be on your network. This can be either a host on your network with a public IP, or a host in your DMZ that has a public IP (both examples are shown below).
It takes longer to explain what DNS doctoring is, than it does to actually set it up. Essentially you simply add the 'dns' keyword to the end of the static nat statement for the internal host to its public address.
Option 1 - DNS Doctoring for a host on your LAN
This is simply a one-to-one static nat with the dns keyword added onto it, so using the example above (on the left), lets take a look at our NATs.
Petes-ASA# show run nat ! object network obj_any nat (inside,outside) dynamic interface object network Obj-Static-220.127.116.11 nat (inside,outside) static 18.104.22.168
You may have a lot more output, but this tells me theres a dynamic NAT for all network traffic (PAT everything to the outside interface dynamically). And a static translation for your internal host, that's the one we need to add the dns keyword to.
Petes-ASA# configure terminal Petes-ASA(config)# object network Obj-Static-22.214.171.124 Petes-ASA(config-network-object)# nat (inside,outside) static 126.96.36.199 dns Petes-ASA(config-network-object)# exit Petes-ASA(config)# write mem Building configuration... Cryptochecksum: de650019 1f1583f7 70121512 e1d093e8 15724 bytes copied in 3.430 secs (5241 bytes/sec) [OK] Petes-ASA(config)#
Testing DNS Doctoring
Heres an example of whatÂ happened before we setup DNS doctoring, (or where DNS doctoring is not working).
And once its been configured do the same and note the difference;