M.I.T. DEPARTMENT OF EECS
|6.033 - Computer System Engineering||DNS Hands-On Assignment|
Complete the following hands-on assignment. Do the activities described, and hand in the answers to the numbered questions at the beginning of recitation on Tuesday, March 30. As usual, submit your solutions using the online submission site before recitation.
This hands-on exercise is designed to introduce you to the Internet's Domain Name System (DNS). You probably use DNS every day --- you used it to get to this page. To prepare for this assignment, please read Section 4.4 of the class textbook, titled "Case study: The Internet Domain Name System (DNS)".
A good tool for exploring DNS is
dig, short for Domain Information Groper.
dig should be available on all recent
Athena workstations. It should work by default, but if it does not,
please try running
add watchmaker first. If that still
does not work, try an Athena Sun workstation.
Here is an example use of
athena% dig slashdot.org
; <<>> DiG 9.3.1 <<>> slashdot.org ;; global options: printcmd ;; Got answer: ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 997 ;; flags: qr rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 3, ADDITIONAL: 3
;; QUESTION SECTION: ;slashdot.org. IN A
;; ANSWER SECTION: slashdot.org. 3600 IN A 184.108.40.206 (*)
;; AUTHORITY SECTION: slashdot.org. 86399 IN NS ns-2.ch3.sourceforge.com. slashdot.org. 86399 IN NS ns-1.ch3.sourceforge.com. slashdot.org. 86399 IN NS ns-1.sourceforge.com. ;; ADDITIONAL SECTION: ns-1.ch3.sourceforge.com. 172800 IN A 220.127.116.11 ns-1.sourceforge.com. 172800 IN A 18.104.22.168 ns-2.ch3.sourceforge.com. 172800 IN A 22.214.171.124
;; Query time: 69 msec ;; SERVER: 127.0.0.1#53(127.0.0.1) ;; WHEN: Wed Mar 11 17:32:51 2009 ;; MSG SIZE rcvd: 170
dig performs a DNS lookup and prints information
about the request and the response it received.
If you run dig, you may see results that differ from those
At the bottom, we can see that the query was
sent to our default server (
127.0.0.1), and that it
took roughly 69 msecs to respond. Most of the information we are
interested in is in the
ANSWER section, marked with
(*) above. Let's examine
that section more closely:
;; ANSWER SECTION: slashdot.org. 3600 IN A 126.96.36.199 name expire class type data (IP)We can see that this result is of type
A, an address record: it is telling us that the IP address for the name "
188.8.131.52. The expiry time field "
3600" indicates that this record/entry is valid for 3600 seconds (1 hour). You can ignore the "class" field; this is nearly always
AUTHORITY section contains records of type
indicating the names of DNS servers that have name records for a
particular domain. Here, we can see that three DNS servers
ns-2.ch3.sourceforge.com.) are responsible for
answering requests for names in the
We can ask a specific server (instead of the default) for information about a host by using the following syntax:
athena% dig @amsterdam.lcs.mit.edu slashdot.org
; <<>> DiG 9.3.1 <<>> @amsterdam.lcs.mit.edu slashdot.org ; (1 server found) ;; global options: printcmd ;; Got answer: ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 1988 ;; flags: qr rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 3, ADDITIONAL: 3
;; QUESTION SECTION: ;slashdot.org. IN A
;; ANSWER SECTION: slashdot.org. 3600 IN A 184.108.40.206 ...[output truncated]
(recursion desired) flag indicates that
dig requested a recursive
lookup, and the
ra (recursion available) flag indicates
that the server permits recursive lookups (some do not).
dig only prints the final result of the recursive search.
You can mimic the individual steps of a recursive search
by sending a request to a particular DNS server and asking for no
+norecurs flag. For example, to send a
non-recursive query to one of the root servers:
athena% dig @a.ROOT-SERVERS.NET www.slashdot.org +norecurs
; <<>> DiG 9.3.1 <<>> @a.ROOT-SERVERS.NET www.slashdot.org +norecurs ;; (1 server found) ;; global options: printcmd ;; Got answer: ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 1888 ;; flags: qr; QUERY: 1, ANSWER: 0, AUTHORITY: 6, ADDITIONAL: 12
;; QUESTION SECTION: ;www.slashdot.org. IN A
;; AUTHORITY SECTION: org. 172800 IN NS B0.ORG.AFILIAS-NST.org. org. 172800 IN NS A0.ORG.AFILIAS-NST.INFO. org. 172800 IN NS A2.ORG.AFILIAS-NST.INFO. org. 172800 IN NS D0.ORG.AFILIAS-NST.org. org. 172800 IN NS C0.ORG.AFILIAS-NST.INFO. org. 172800 IN NS B2.ORG.AFILIAS-NST.org. ;; ADDITIONAL SECTION: A0.ORG.AFILIAS-NST.INFO. 172800 IN A 220.127.116.11 A0.ORG.AFILIAS-NST.INFO. 172800 IN AAAA 2001:500:e::1 A2.ORG.AFILIAS-NST.INFO. 172800 IN A 18.104.22.168 A2.ORG.AFILIAS-NST.INFO. 172800 IN AAAA 2001:500:40::1 B0.ORG.AFILIAS-NST.org. 172800 IN A 22.214.171.124 B0.ORG.AFILIAS-NST.org. 172800 IN AAAA 2001:500:c::1 B2.ORG.AFILIAS-NST.org. 172800 IN A 126.96.36.199 B2.ORG.AFILIAS-NST.org. 172800 IN AAAA 2001:500:48::1 C0.ORG.AFILIAS-NST.INFO. 172800 IN A 188.8.131.52 C0.ORG.AFILIAS-NST.INFO. 172800 IN AAAA 2001:500:b::1 D0.ORG.AFILIAS-NST.org. 172800 IN A 184.108.40.206 D0.ORG.AFILIAS-NST.org. 172800 IN AAAA 2001:500:f::1 ;; Query time: 84 msec ;; SERVER: 220.127.116.11#53(18.104.22.168) ;; WHEN: Wed Mar 11 17:45:41 2009 ;; MSG SIZE rcvd: 436As you can see, the server does not know the answer and instead provides information about the servers most likely to be able to provide authoritative information. In this case, the best the root server knows is the identities of the servers for the
Here are some exercises.
You should submit answers only to the
questions asked. In particular, please do not include pages of output
dig unless specifically requested. As usual, submit your solutions using the online submission site, before recitation.
dig, find the IP address for
thyme.lcs.mit.edu. What is the IP address?
thymeincludes a record of type
CNAME. In the terminology of chapter 4, what does
dig +domain=mit.edu ai dig +domain=mit.edu ai.What are the two resulting IP addresses?
For this problem, you will go through the steps of resolving a
particular hostname, mimicing a standard recursive query.
Assuming it knows nothing
else about a name, a DNS resolver will ask a well-known root
server. The root servers on the Internet are
in the domain
root-servers.net. One way to get a list
of them is with the command:
athena% dig . ns
digto ask one of the root servers the address of
lirone.csail.mit.edu, without recursion. What command do you use to do this?
lirone.csail.mit.edu. What commands did you use to do this? What IP address did you find for lirone?
www.dmoz.org. What command did you use? Did your default server have the answer in its cache? How do you know? How long did this query take? If this information was cached, please find some other host name that is not cached and do this section with that other host.