Fun With DNS: Three Useful Commands

The DNS is a distributed, hierarchical database where authority flows from the top (or root) of the hierarchy downward. When thinking of the structure of the DNS, imagine an inverted tree. Each branch of the tree is within a zone of authority; however, multiple branches of the tree can be within a single zone. The software (Bind being the most common) that stores domain name information is called a domain name server. A single name server can be authoritative for multiple zones. All zones have a primary master and a secondary master name server that provides authoritative responses for their zones. If you query a name server not authoritative for a particular zone, that name server will most likely have up-to-date information. This is because zone information propagates throughout the Internet at regular intervals, and name servers cache zone information for which they are not authoritative. DNS Commands There are three crucial commands that can put all the DNS information you need at your fingertips. The way to use this article is to try each of the commands listed on a domain name, so you can see what the output looks like. Learn by doing! Zone file database records divide DNS information into three primary types: NS (Name Server) records, MX (Mail Exchange) records, and A (Address) records. NS records indicate the name servers. MX records indicate the hosts that handle e-mail delivery; the priority (pri) number indicates the order in which mail servers are used, with the lowest number receiving the highest priority. The A (Address) records map hostnames to IP addresses, the real names of machines. host This is the simplest of the DNS commands. It is a quick way to determine the IP address of a hostname: : host www.your-domain-name.com The -a option will return all of the DNS information in verbose format. : host -a www.your-domain-name.com Now that you know the IP address for www.your-domain-name.com, try a reverse lookup. : host dig (domain information groper) This command gathers and returns DNS information in a format the name server can use directly. You will find it easy to query specific name servers with dig. You can quickly determine the Name servers of your host or any other host: : dig ns your-host.com Then you check your (or another) website against the host's name servers: : dig www.your-domain-name.com @ns.your-host.com Dig can provide output that is in the same format as the zone file itself. Here is how to get the whole zone file: : dig any your-domain-name.com Here are the most useful dig query types: dig any (gathers all DNS information), dig ns (gathers name server information), dig mx (gathers mail exchanger information) and dig a (gathers network address information). The dig command can also do reverse lookups with output formatted for the zone file: : dig -x nslookup You can use this tool as a single line command, or you can use it interactively, which distinguishes it from the other DNS commands. Once you have started nslookup, type set all to list the default options. As with dig you can choose the server (name server) you want to query, and you can decide the type of DNS information on which to focus. Just as you can issue commands to nslookup interactively, you can also change the initial defaults by starting a .nslookuprc file. The format of the .nslookup is one command per line: set type=NS set domain=srvns.your-host.com set timeout=10 Conclusion These three commands can provide you with most of the information you need about your domain names. They are powerful tools, and this article should provide you enough information to get started or offer a quick refresher if you already use these commands.