Why Names? - ECSE - Rensselaer Polytechnic Institute
Download
Report
Transcript Why Names? - ECSE - Rensselaer Polytechnic Institute
Domain Name System (DNS)
NA M
E
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
[email protected]
http://www.ecse.rpi.edu/Homepages/shivkuma
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
1
Overview
Naming hierarchy
Server hierarchy
Name resolution
Other information in name servers
Ref: Chap 14, RFC 1034
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
2
Why Names?
Computers use addresses
Humans cannot remember IP addresses
Need names
Example, “shiva” for 128.113.50.56
Simplest Solution: Each computer has a unique
name and has a built in table of name to address
translation (mapping)
Problem: Not scalable
Solution: DNS (Adopted in 1983)
Hierarchical Names: shiv.ecse.rpi.edu
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
3
Name Hierarchy
Unnamed root
com
edu
gov
au
dec
rpi
nsf
co
ecse
ipl
hr
...
us
va
reston
cnri
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
4
Name Hierarchy
Unique domain suffix is assigned by Internet
Authority
The domain administrator has complete control
over the domain
No limit on number of sub-domains or number of
levels
computer.site.division.company.com
Domains within an organization do not have to
be uniform in number of subdomains or levels
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
5
Name Hierarchy (Continued)
Name space is not related to physical
interconnection, e.g., ecse.rpi.edu and ipl.rpi.edu
could be on the same floor or in different cities
Geographical hierarchy is also allowed, e.g.,
cnri.reston.va.us
A name could be a subdomain (eg: ecse.rpi.edu)
or an individual object (eg: cortez.rpi.edu)
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
6
Top Level Domains
Domain Name/Assignment
com
Commercial
edu
Educational
gov
Government
mil
Military
net
Network
org
Other organizations
arpa
Advanced Research Project Agency
country code au, uk, ca
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
7
Server Hierarchy
Servers are organized in a hierarchy
Each server has an authority over a part of the
naming hierarchy
It needs to know other servers who are
responsible for other subdomains
A single node in the naming tree cannot be split
among multiple servers
A given level of hierarchy can be partitioned into
multiple servers
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
8
Server Hierarchy (Example)
com
com
foobar
foobar
soap
soap
candy
candy
peanut almond walnut
peanut almond
walnut
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
9
Server Hierarchy (Continued)
Authority has the name to address translation
table
Responsible Either has the name to address
translation table or knows the server who has
But such a reply is called “non-authoritative”
reply
Root server knows about servers for top-level
domains, e.g., com
Each server knows the root server
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
10
Server Hierarchy: Example
Root
Server
Server
for com
Server
for edu
Server
for gov
Server
for au
Server
for us
Server for
dec.com
Server
for rpi.edu
Server for
nsf.gov
server for
co.au
Server for
va.us
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
11
Server Hierarchy: Better
Root
Server
Server for
dec.com
Server
for rpi.edu
Server for
nsf.gov
server for
co.au
Server for
va.us
Fewer servers
More entries/links per server
Fewer levels to traverse before resolving a name
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
12
Name Resolution
Each computer has a name resolver routine,
e.g., gethostbyname & gethostbyaddr in UNIX
Each resolver knows the IP address of a local
DNS server
Resolver sends a DNS request to the server
DNS server either gives the answer, forwards the
request to another server, or gives a referral
Referral = Next server to whom request should
be sent
Recursive Query:
Give me an answer (Don't give me a referral)
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
13
Recursion!
Cache
Cache
Query
Query
Response
Response
Name
Server
Query
Database
Name
Server
Database
Query
Name
User
Response Resolver Response
Cache
Name
Server
Cache
Database
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
14
Name Resolution (Continued)
Name
Server
Name
Server
Query
Response
Query
Database
Query
Name
User
Response Resolver Response
Rensselaer Polytechnic Institute
Referral
Cache
Query
Database
Cache
Name
Server
Cache
Cache
Database
Shivkumar Kalyanaraman
15
DNS Optimization
Spatial Locality: Local computers referenced
more often than remote
Temporal Locality: Same set of domains
referenced repeatedly Caching
Each entry has a time to live (TTL)
Replication: Multiple servers. Multiple roots.
Ask the geographically closest server.
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
16
DNS Message Format
Identification
Parameter
Number of Questions
Number of Answers
Number of Authority
Number of Additional
Question Section
...
Answer Section
...
Authority Section
...
Additional Information Section
...
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
17
Format (Continued)
Format of the query section entries:
Query Domain Name
...
Query Type
Query Class
Format of other section entries:
Resource Domain Name
Type
Class
Time to live
Resource Data Length Resource Data
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
18
DNS Message Format (Continued)
Bit
0
1-4
Meaning
Operation: 0=Query, 1=Response
Query type: 0=Standard, 1=Inverse, 2,3
obsolete
5
Set if answer authoritative
6
Set if message truncated
7
Set if recursion desired
8
Set if recursion available
9-11 Reserved
12-15 Response type: 0=No error, 1=Format error,
2=Server Failure, 3=Name does not exist
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
19
Types of DNS Entries
DNS used other types of resolution
Eg: also for finding mail server, pop server,
responsible person, etc for a computer
DNS database has multiple “types”
Record type A Address of X
Record type MX Mail exchanger of X
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
20
Types of DNS Entries (Continued)
DNS database may also have multiple “classes”
Can support name resolution for multiple
protocols eg: IP, SNA, DECbit etc
Pointer queries: given IP address find name
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
21
Resource Record Types
Type
A
CNAME
HINFO
MINFO
MX
NS
PTR
RP
SOA
TXT
Meaning
Host Address
Canonical Name (alias)
CPU and O/S
Mailbox Info
Mail Exchanger
Authoritative name server for a domain
Pointer to a domain name (link)
Responsible person
Start of zone authority (Which part of
naming hierarchy implemented)
Arbitrary Text
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
22
Summary
DNS: Maps names to addresses
Names are hierarchical. Administration is also
hierarchical.
No standard for number of levels
Replication and caching is used for performance
optimization.
Shivkumar Kalyanaraman
Rensselaer Polytechnic Institute
23