dns

70
STRUCTURED NAMING INTERNET N AMING SER VICE: DNS*

Upload: patruni-chidananda-sastry

Post on 21-Jan-2017

352 views

Category:

Engineering


0 download

TRANSCRIPT

Page 1: Dns

STRUCTURED NAMING

INTERNET NAMING SERVICE: D

NS*

Page 2: Dns

OVERVIEWIntroduction to the DNSDNS ComponentsDNS Structure and HierarchyThe DNS in Context

Page 3: Dns

DNS HISTORY (1)ARPANET utilized a central file HOSTS.TXT

Contains names to addresses mapping Maintained by SRI’s NIC (Stanford-Research-Institute: Network-

Information-Center)

Administrators email changes to NIC NIC updates HOSTS.TXT periodically

Administrators FTP (download) HOSTS.TXT

Page 4: Dns

DNS HISTORY (2)As the system grew, HOSTS.TXT had problems with:

Scalability (traffic and load) Name collisions Consistency

In 1984, Paul Mockapetris released the first version (RFCs 882 and 883, superseded by 1034 and 1035 …)

Page 5: Dns

THE DNS IS…The “Domain Name System”What Internet users use to reference anything by name on the

InternetThe mechanism by which Internet software translates names to

attributes such as addresses

Page 6: Dns

THE DNS IS ALSO…A globally distributed, scalable,

reliable databaseComprised of three componentsA “name space”Servers making that name space availableResolvers (clients) which query the servers about the name space

Page 7: Dns

DNS AS A LOOKUP MECHANISMUsers generally prefer names to numbers

Computers prefer numbers to names

DNS provides the mapping between the two I have “x”, give me “y”

Page 8: Dns

DNS AS A DATABASEKeys to the database are “domain names” www.foo.com, 18.in-addr.arpa, 6.4.e164.arpaOver 200,000,000 domain names storedEach domain name contains one or more attributes Known as “resource records”Each attribute individually retrievable

Page 9: Dns

GLOBAL DISTRIBUTIONData is maintained locally, but retrievable globally No single computer has all DNS dataDNS lookups can be performed by any deviceRemote DNS data is locally cachable to improve performance

Page 10: Dns

LOOSE COHERENCYEach version of a subset of the database

(a zone) has a serial numberThe serial number is incremented on each database change

Changes to the master copy of the database are propagated to replicas according to timing set by the zone administrator

Cached data expires according to timeout set by zone administrator

Page 11: Dns

SCALABILITYNo limit to the size of the databaseNo limit to the number of queries Tens of thousands of queries handled easily every secondQueries distributed among masters, slaves, and caches

Page 12: Dns

RELIABILITYData is replicatedData from master is copied to multiple slavesClients can queryMaster serverAny of the copies at slave serversClients will typically query local cachesDNS protocols can use either UDP or TCP If UDP, DNS protocol handles retransmission, sequencing, etc.

Page 13: Dns

DYNAMICITYDatabase can be updated dynamically Add/delete/modify of any record Only master can be dynamically updated

Modification of the master database triggers replication

Page 14: Dns

OVERVIEWIntroduction to the DNSDNS Components The name space The servers The resolversDNS Structure and HierarchyThe DNS in Context

Page 15: Dns

THE NAME SPACEThe name space is the structure of the

DNS database An inverted tree with the root node at the topEach node has a label The root node has a null label, written as “”

th ird -le ve l n o de

se co n d-le ve l no de s e co n d -le ve l no de

to p -le ve l no de

th ird -le v e l n o de th ird -le v e l n o de

se co n d-le ve l no de

to p -le ve l no de

s e co n d -le ve l no de se co n d -le ve l no de

to p -le ve l no de

T h e roo t no de""

Page 16: Dns

AN ANALOGY – E.164Root node maintained by the ITU (call it “+”)Top level nodes = country codes (1, 81, etc)Second level nodes = regional codes (1-402,

81-3, etc.)

. ..

. .. 2 02

6 003

3 81

6 003

7 79

6 50 8 08

1

5 226 2 024

3 489

3 4 8 52

81 ...

"+ "

Page 17: Dns

foo foo

to p -1

foo a t& t

to p -2

b ar b az

to p -3

""

LABELS

Each node in the tree must have a label

A string of up to 63 bytes RFCs 852 and 1123 define legal

characters for “hostnames” A-Z, 0-9, and “-” only with a-z

and A-Z treated as the sameSibling nodes must have

unique labelsThe null label is reserved

for the root node

Page 18: Dns

DOMAIN NAMES

A domain name is the sequence of labels from a node to the root, separated by dots (“.”s), read left to right

The name space has a maximum depth of 127 levels Domain names are limited to 255 characters in length A node’s domain name identifies its position in the name

space

d a ko ta

w e s t

to rna do

e a st w w w

n o m in um m e ta in fo

c om

b e rke ley n w u

e du g ov

n a to

in t

a rm y

m il

uu

n e t o rg

""

Page 19: Dns

SUBDOMAINSOne domain is a subdomain of

another if its domain name ends in the other’s domain name

So sales.nominum.com is a subdomain of nominum.com & com

nominum.com is a subdomain of com

Page 20: Dns

DELEGATIONAdministrators can create subdomains to group

hosts According to geography, organizational affiliation etc.

An administrator of a domain can delegate responsibility for managing a subdomain to someone else

The parent domain retains links to the delegated subdomains

Page 21: Dns

DELEGATION CREATES ZONESEach time an administrator delegates a

subdomain, a new unit of administration is created

The subdomain and its parent domain can now be administered independently

These units are called zonesThe boundary between zones is a point of delegation in the name space

Delegation is good: it is the key to scalability

Page 22: Dns

DIVIDING A DOMAIN INTO ZONES

.a rpa

a cm e bw

m o lo k a i s kye

rw c w w w ftp

g ou da ch e dd ar

a m s

n o m in um n e ts o l

.c om .edu

""

nominum.com domain

nominum.com zone

ams.nominum.com zonerwc.nominum.com

zone

Page 23: Dns

OVERVIEWIntroduction to the DNSDNS Components The name space The servers The resolversDNS Structure and HierarchyThe DNS in Context

Page 24: Dns

NAME SERVERSName servers store information about

the name space in units called “zones”The name servers that load a complete zone are said to “have authority for” or “be authoritative for” the zone

Usually, more than one name server are authoritative for the same zone

This ensures redundancy and spreads the loadAlso, a single name server may be

authoritative for many zones

Page 25: Dns

NAME SERVERS AND ZONES

128.8.10.5nominum.com

204.152.187.11

202.12.28.129

Name Servers

isc.org

Zones128.8.10.5 serves data for both

nominum.com and isc.org zones

202.12.28.129 serves data for nominum.com

zone only

204.152.187.11 serves data for

isc.org zone only

Page 26: Dns

TYPES OF NAME SERVERSTwo main types of serversAuthoritative – maintains the data

Master – where the data is edited Slave – where data is replicated to

Caching – stores data obtained from an authoritative server

No special hardware necessary

Page 27: Dns

NAME SERVER ARCHITECTUREYou can think of a name server as part of: database server, answering queries about the parts of the name

space it knows about (i.e., is authoritative for), cache, temporarily storing data it learns from other name servers,

and agent, helping resolvers and other name servers find data

Page 28: Dns

NAME SERVER ARCHITECTURE

MasterserverZone transfer

Zonedatafile

Fromdisk

Authoritative Data(primary master and

slave zones)

Agent(looks up queries

on behalf of resolvers)

Cache Data(responses from

other name servers)

Name Server Process

Page 29: Dns

AUTHORITATIVE DATA

ResolverQuery

Response

Authoritative Data(primary master and

slave zones)

Agent(looks up queries

on behalf of resolvers)

Cache Data(responses from

other name servers)

Name Server Process

Page 30: Dns

USING OTHER NAME SERVERS

Anothernameserver

Response

ResolverQuery

Query

Authoritative Data(primary master and

slave zones)

Agent(looks up queries

on behalf of resolvers)

Cache Data(responses from

other name servers)

Name Server Process

Response

Page 31: Dns

CACHED DATA

Query

Response

Authoritative Data(primary master and

slave zones)

Agent(looks up queries

on behalf of resolvers)

Cache Data(responses from

other name servers)

Name Server Process

Resolver

Page 32: Dns

OVERVIEWIntroduction to the DNSDNS Components The name space The servers The resolversDNS Structure and HierarchyThe DNS in Context

Page 33: Dns

NAME RESOLUTIONName resolution is the process by which

resolvers and name servers cooperate to find data in the name space

Closure mechanism for DNS?Starting point: the names and IP addresses of the name servers for the root zone (the “root name servers”)

The root name servers know about the top-level zones and can tell name servers whom to contact for all TLDs

Page 34: Dns

NAME RESOLUTIONA DNS query has three parameters:A domain name (e.g., www.nominum.com),

Remember, every node has a domain name!A class (e.g., IN), andA type (e.g., A)http://network-tools.com/nslook/Upon receiving a query from a

resolver, a name server1) looks for the answer in its authoritative data and its cache

2) If step 1 fails, the answer must be looked up

Page 35: Dns

ping www.nominum.com.

THE RESOLUTION PROCESSLet’s look at the resolution process step-by-step:

annie.west.sprockets.com

Page 36: Dns

What’s the IP address of

www.nominum.com?

THE RESOLUTION PROCESS

The workstation annie asks its configured name server, dakota, for www.nominum.com’s address

ping www.nominum.com.annie.west.sprockets.com

dakota.west.sprockets.com

Page 37: Dns

THE RESOLUTION PROCESS

The name server dakota asks a root name server, m, for www.nominum.com’s address

ping www.nominum.com.annie.west.sprockets.com

m.root-servers.net

dakota.west.sprockets.com

What’s the IP address of

www.nominum.com?

Page 38: Dns

THE RESOLUTION PROCESS

The root server m refers dakota to the com name servers

This type of response is called a “referral”

ping www.nominum.com.annie.west.sprockets.com

m.root-servers.net

dakota.west.sprockets.com Here’s a list of the com name servers.

Ask one of them.

Page 39: Dns

THE RESOLUTION PROCESS

The name server dakota asks a com name server, f, for www.nominum.com’s address

ping www.nominum.com.annie.west.sprockets.com

m.root-servers.net

dakota.west.sprockets.com

What’s the IP address of

www.nominum.com?

f.gtld-servers.net

Page 40: Dns

THE RESOLUTION PROCESS

The com name server f refers dakota to the nominum.com name servers

ping www.nominum.com.annie.west.sprockets.com

f.gtld-servers.net

m.root-servers.net

dakota.west.sprockets.com

Here’s a list of the nominum.com name servers.

Ask one of them.

Page 41: Dns

THE RESOLUTION PROCESS

The name server dakota asks a nominum.com name server, ns1.sanjose, for www.nominum.com’s address

ping www.nominum.com.annie.west.sprockets.com

f.gtld-servers.net

m.root-servers.net

dakota.west.sprockets.com

ns1.sanjose.nominum.net

What’s the IP address of

www.nominum.com?

Page 42: Dns

THE RESOLUTION PROCESS

The nominum.com name server ns1.sanjose responds with www.nominum.com’s address

ping www.nominum.com.annie.west.sprockets.com

f.gtld-servers.net

m.root-servers.net

dakota.west.sprockets.com

ns1.sanjose.nominum.netHere’s the IP address for

www.nominum.com

Page 43: Dns

Here’s the IP address for

www.nominum.com

THE RESOLUTION PROCESS

The name server dakota responds to annie with www.nominum.com’s address

ping www.nominum.com.annie.west.sprockets.com

f.gtld-servers.net

m.root-servers.net

dakota.west.sprockets.com

ns1.sanjose.nominum.net

Page 44: Dns

ping ftp.nominum.com.

RESOLUTION PROCESS (CACHING)

After the previous query, the name server dakota now knows:

The names and IP addresses of the com name serversThe names and IP addresses of the nominum.com name servers

The IP address of www.nominum.comLet’s look at the resolution process again

annie.west.sprockets.com

Page 45: Dns

ping ftp.nominum.com.

What’s the IP address of ftp.nominum.com?

RESOLUTION PROCESS (CACHING)

The workstation annie asks its configured name server, dakota, for ftp.nominum.com’s address

annie.west.sprockets.com

f.gtld-servers.net

m.root-servers.net

dakota.west.sprockets.com

ns1.sanjose.nominum.net

Page 46: Dns

ping ftp.nominum.com.

What’s the IP address of ftp.nominum.com?

RESOLUTION PROCESS (CACHING)

dakota has cached a NS record indicating ns1.sanjose is an nominum.com name server, so it asks it for ftp.nominum.com’s address

annie.west.sprockets.com

f.gtld-servers.net

m.root-servers.net

dakota.west.sprockets.com

ns1.sanjose.nominum.net

Page 47: Dns

ping ftp.nominum.com.

Here’s the IP address for

ftp.nominum.com

RESOLUTION PROCESS (CACHING)

The nominum.com name server ns1.sanjose responds with ftp.nominum.com’s address

annie.west.sprockets.com

f.gtld-servers.net

m.root-servers.net

dakota.west.sprockets.com

ns1.sanjose.nominum.net

Page 48: Dns

ping ftp.nominum.com.

Here’s the IP address for

ftp.nominum.com

RESOLUTION PROCESS (CACHING)

The name server dakota responds to annie with ftp.nominum.com’s address

annie.west.sprockets.com

f.gtld-servers.net

m.root-servers.net

dakota.west.sprockets.com

ns1.sanjose.nominum.net

Page 49: Dns

ITERATIVE NAME RESOLUTIONThe principle of iterative name resolution.

Page 50: Dns

RECURSIVE NAME RESOLUTION (1)The principle of recursive name

resolution.

Page 51: Dns

RECURSIVE NAME RESOLUTION (2)

Recursive name resolution of <nl, vu, cs, ftp>. Name servers cache intermediate results for subsequent lookups.

Server for node

Should resolve Looks up Passes to

childReceives and caches

Returns to requester

cs <ftp> #<ftp> -- -- #<ftp>

vu <cs,ftp> #<cs> <ftp> #<ftp> #<cs>#<cs, ftp>

ni <vu,cs,ftp> #<vu> <cs,ftp> #<cs>#<cs,ftp>

#<vu>#<vu,cs>#<vu,cs,ftp>

root <ni,vu,cs,ftp> #<nl> <vu,cs,ftp> #<vu>#<vu,cs>#<vu,cs,ftp>

#<nl>#<nl,vu>#<nl,vu,cs>#<nl,vu,cs,ftp>

Page 52: Dns

ITERATIVE VERSUS RECURSIVE RESOLUTION (1)

Performance-wise, which is better?Which works better with caching?How about communication cost?

Page 53: Dns

ITERATIVE VERSUS RECURSIVE RESOLUTION (2)

Performance-wise, which is better? Recursive method puts higher performance demand on each name

server

Which works better with caching? Recursive method works better with caching

How about communication cost? Recursive method can reduce communication cost

Page 54: Dns

ITERATIVE VERSUS RECURSIVE RESOLUTION (3)

The comparison between recursive and iterative name resolution with respect to communication costs.

Page 55: Dns

OVERVIEWIntroduction to the DNSDNS ComponentsDNS Structure and HierarchyThe DNS in Context

Page 56: Dns

DNS STRUCTURE AND HIERARCHY

The DNS imposes no constraints on how the DNS hierarchy is implemented except:

A single rootThe label restrictions So, can we create a host with a name a.wonderful.world?If a site is not connected to the Internet, it can

use any domain hierarchy it choosesCan make up whatever TLDs (top level domains) you wantConnecting to the Internet implies use of the

existing DNS hierarchy

Page 57: Dns

TOP-LEVEL DOMAIN (TLD) STRUCTURE

In 1983 (RFC 881), the idea was to have TLDs correspond to network service providers

e.g., ARPA, DDN, CSNET, etc. Bad idea: if your network changes, your name changes

By 1984 (RFC 920), functional domains was established

e.g., GOV for Government, COM for commercial, EDU for education, etc.

RFC 920 also Provided country domains Provided “Multiorganizations”

Large, composed of other (particularly international) organizations Provided a stable TLD structure until 1996 or so

Page 58: Dns

THE CURRENT TLDS

C O MC o m m e rc ia l O rg a n iza t io ns

N E TN e tw o rk In fra stru c tu re

O R GO th er O rga n iza t io ns

G e n e ric T L Ds(gT L D s )

A FA fghan is tan

A LA lb a n ia

D ZA lg e ria

...

Y UY u g os la v ia

Z MZ a m b ia

Z WZ im ba b we

C o un try C od e T LD s(ccT L D s )

IN TIn te rna tion a l T re a t y O rga n izatio ns

A R P A(T ra ns it ion D e v ice )

In te rn a tion a l T L D s(iT LD s )

G O VG o vern m e n ta l O rgan iza t io ns

M ILM ilita ry O rga n iz a tio n s

E D UE duca tio n al In stitu tio ns

U S Le g acy T L Ds(u sT L D s )

" ."

Page 59: Dns

INTERNET CORPORATION FOR ASSIGNED NAMES AND NUMBERS (ICANN)ICANN’s role: to oversee the

management of Internet resources including

Addresses Delegating blocks of addresses to the regional registries

Protocol identifiers and parameters Allocating port numbers, etc.

Names Administration of the root zone file Oversee the operation of the root name servers

Page 60: Dns

THE ROOT NAMESERVERSThe root zone file lists the names and IP

addresses of the authoritative DNS servers for all top-level domains (TLDs)

The root zone file is published on 13 servers, “A” through “M”, around the Internet

Root name server operations currently provided by volunteer efforts by a very diverse set of organizations

Page 61: Dns

ROOT NAME SERVER OPERATORS

Nameserver Operated by:

A Verisign (US East Coast)

B University of S. California –Information Sciences Institute (US West Coast)

C Cogent Communications (US East Coast)

D University of Maryland (US East Coast)

E NASA (Ames) (US West Coast)

F Internet Software Consortium (US West Coast)

G U. S. Dept. of Defense (ARL) (US East Coast)

H U. S. Dept. of Defense (DISA) (US East Coast)

I Autonomica (SE)

J Verisign (US East Coast)

K RIPE-NCC (UK)

L ICANN (US West Coast)

M WIDE (JP)

Page 62: Dns

REGISTRIES, REGISTRARS, AND REGISTRANTS

A classification of roles in the operation of a domain name space

Registry the name space’s database the organization which has edit control of that database the organization which runs the authoritative name servers for that name space

Registrar the agent which submits change requests to the registry on behalf of the registrant

Registrant the entity which makes use of the domain name

Page 63: Dns

REGISTRIES, REGISTRARS, AND REGISTRANTS

Registry Zone DB

Registrants

End user requests add/modify/delete

Registrar submits add/modify/delete to registry

Registrar RegistrarRegistrar

Masterupdated

Registry updateszone

Slaves updated

Page 64: Dns

VERISIGN: THE REGISTRY AND REGISTRAR FOR GTLDS.COM, .NET, and .ORGBy far the largest top level domains on the Internet today

Verisign received the contract for the registry for .COM, .NET, and .ORG

also a registrar for these TLDs

Page 65: Dns

OVERVIEWIntroduction to the DNSDNS ComponentsDNS HierarchyThe DNS in Context

Page 66: Dns

LOAD CONCERNSDNS can handle the load DNS root servers get approximately 3000 queries per second

Empirical proofs (DDoS attacks) show root name servers can handle 50,000 queries per second Limitation is network bandwidth, not the DNS protocol

in-addr.arpa zone, which translates numbers to names, gets about 2000 queries per second

Page 67: Dns
Page 68: Dns

PERFORMANCE CONCERNSDNS is a very lightweight protocol Simple query – responseAny performance limitations are the result of network

limitations Speed of light Network congestion Switching/forwarding latencies

Page 69: Dns

SECURITY CONCERNSBase DNS protocol (RFC 1034, 1035) is

insecureDNS spoofing (cache poisoning) attacks are possibleDNS Security Enhancements (DNSSEC, RFC

2565) remedies this flawBut creates new ones

DoS attacks Amplification attacks

DNSSEC strongly discourages large flat zones

Hierarchy (delegation) is good

Page 70: Dns

QUESTIONS?