1 / 250

Introduction to the DNS system

Introduction to the DNS system. Bill Manning bmanning@ep.net. Administrative Constraints. RFC’s 1219 1591 2010 ICP-1. RFC’s. RFC 1219 – re-interates – two servers MINIMUM, separate power grids, different administration.

zeph-hill
Download Presentation

Introduction to the DNS system

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Introduction to the DNS system Bill Manning bmanning@ep.net slideset 1

  2. Administrative Constraints • RFC’s • 1219 • 1591 • 2010 • ICP-1

  3. RFC’s • RFC 1219 – re-interates – two servers MINIMUM, separate power grids, different administration. • RFC 1591 – Community service, Accurate contact data, Responsible, cooperative parties in the shared responsibility of the delegation • RFC 2010 – The first pass at loading observations/documentation – Parents have a responsibility to teach their children.

  4. ICP-1 • ICANNs codification of these principles for TLD operators. • Not much new defined, save contractual language and escrow powers (contraversial)

  5. Notes DNS0/ICANN/CENTR • Tendancy to run TLD as a standalone value proposition • Contracts/SLA’s may seem more important than they are. • Herding tendencies (small number of sites slaving many TLD zones) • Hiding data. (It’s a public resource)

  6. Preparing for the future • New features • Better data integrity • Community cooperation builds trust • Teaching your delegations their responsibilities.

  7. Introduction to the DNS system Bill Manning bmanning@ep.net slideset 1

  8. Purpose of naming • Addresses are used to locate objects • Names are easier to remember than numbers • You would like to get to the address or other objects using a name • DNS provides a mapping from names to resources of several types

  9. Names and addresses in general • An address is how you get to an endpoint • Typically, hierarchical (for scaling): • 950 Charter Street, Redwood City CA, 94063 • 204.152.187.11, +1-650-381-6003 • A “name” is how an endpoint is referenced • Typically, no structurally significant hierarchy • “David”, “Tokyo”, “itu.int”

  10. Naming History • 1970’s ARPANET • Host.txt maintained by the SRI-NIC • pulled from a single machine • Problems • traffic and load • Name collisions • Consistency • DNS created in 1983 by Paul Mockapetris (RFCs 1034 and 1035), modified, updated, and enhanced by a myriad of subsequent RFCs

  11. DNS • A lookup mechanism for translating objects into other objects • A globally distributed, loosely coherent, scalable, reliable, dynamic database • Comprised of three components • A “name space” • Servers making that name space available • Resolvers (clients) which query the servers about the name space

  12. DNS Features: Global Distribution • Data is maintained locally, but retrievable globally • No single computer has all DNS data • DNS lookups can be performed by any device • Remote DNS data is locally cachable to improve performance

  13. DNS Features: Loose Coherency • The database is always internally consistent • Each version of a subset of the database (a zone) has a serial number • The serial number is incremented on each database change • Changes to the master copy of the database are replicated according to timing set by the zone administrator • Cached data expires according to timeout set by zone administrator

  14. DNS Features: Scalability • No limit to the size of the database • One server has over 20,000,000 names • Not a particularly good idea • No limit to the number of queries • 24,000 queries per second handled easily • 2,000-4,000 qps is more “normal” • Queries distributed among masters, slaves, and caches

  15. DNS Features: Reliability • Data is replicated • Data from master is copied to multiple slaves • Clients can query • Master server • Any of the copies at slave servers • Clients will typically query local caches • DNS protocols can use either UDP or TCP • If UDP, DNS protocol handles retransmission, sequencing, etc.

  16. DNS Features: Dynamicity • Database can be updated dynamically • Add/delete/modify of almost any record • Modification of the master database triggers replication • Only master can be dynamically updated • Creates a single point of failure

  17. DNS Concepts • Next slides are about concepts • After this set of slides you should understand • How the DNS is built • Why it is built the way it is • The terminology used throughout the course

  18. Concept: DNS Names 1 • The namespace needs to be made hierarchical to be able to scale. • The idea is to name objects based on • location (within country, set of organizations, set of companies, etc) • unit within that location (company within set of company, etc) • object within unit (name of person in company)

  19. Concept: DNS Names 2How names appear in the DNS Fully Qualified Domain Name (FQDN) WWW.EP.NET. • labels separated by dots • DNS provides a mapping from FQDNs to resources of several types • Names are used as a key when fetching data in the DNS Note the trailing dot

  20. Concept: Resource Records • The DNS maps names into data using Resource Records. • More detail later Resource Record www.ep.net. … A 10.10.10.2 Address Resource

  21. ws1 ws2 ftp • www www disi • sun • ripe isi tislabs moon • • • google net edu com • Concept: DNS Names 3 • Domain names can be mapped to a tree. • New branches at the ‘dots’ • No restriction to the amount of branches.

  22. com domain • com net edu google ripe.net domain • sun • • ripe tislabs moon isi • net domain • disi www www ftp • ws2 ws1 Concept: Domains • Domains are “namespaces” • Everything below .com is in the com domain. • Everything below ripe.net is in the ripe.net domain and in the net domain.

  23. Delegation • Administrators can create subdomains to group hosts • According to geography, organizational affiliation or any other criterion • An administrator of a domain can delegate responsibility for managing a subdomain to someone else • But this isn’t required • The parent domain retains links to the delegated subdomain • The parent domain “remembers” who it delegated the subdomain to

  24. net zone com net domain net edu google • sun • • ripe.net zone ripe tislabs moon isi • • disi www www disi.ripe.net zone ftp • ws2 ws1 Concept: Zones and Delegations • Zones are “administrative spaces” • Zone administrators are responsible for portion of a domain’s name space • Authority is delegated from a parent and to a child

  25. Concept: Name Servers • Name servers answer ‘DNS’ questions. • Several types of name servers • Authoritative servers • master (primary) • slave (secondary) • (Caching) recursive servers • also caching forwarders • Mixture of functionality

  26. Concept: Name Serversauthoritative name server • Give authoritative answers for one or more zones. • The master server normally loads the data from a zone file • A slave server normally replicates the data from the master via a zone transfer slave master slave

  27. Concept: Name Serversrecursive server • Recursive servers do the actual lookups; they ask questions to the DNS on behalf of the clients. • Answers are obtained from authoritative servers but the answers forwarded to the clients are marked as not authoritative • Answers are stored for future reference in the cache

  28. Concept: Resolvers • Resolvers ask the questions to the DNS system on behalf of the application. • Normally implemented in a system library (e.g, libc) gethostbyname(char *name); gethostbyaddr(char *addr, int len, type);

  29. Concept: Resolving process & Cache Question: www.ripe.net A root-server www.ripe.net A ? Ask net server @ X.gtld-servers.net (+ glue) www.ripe.net A ? Caching forwarder (recursive) Resolver 192.168.5.10 www.ripe.net A ? gtld-server Ask ripe server @ ns.ripe.net (+ glue) Add to cache www.ripe.net A ? 192.168.5.10 ripe-server

  30. Concept: Resource Records (more detail) • Resource records consist of it’s name, it’s TTL, it’s class, it’s type and it’s RDATA • TTL is a timing parameter • IN class is widest used • There are multiple types of RR records • Everything behind the type identifier is called rdata www.ripe.net. 3600 IN A 10.10.10.2 rdata ttl Label type class

  31. Label ttl class type rdata Example: RRs in a zone file ripe.net 7200 IN SOA ns.ripe.net. olaf.ripe.net. ( 2001061501 ; Serial 43200 ; Refresh 12 hours 14400 ; Retry 4 hours 345600 ; Expire 4 days 7200 ; Negative cache 2 hours ) ripe.net 7200 IN NS ns.ripe.net. ripe.net 7200 IN NS ns.eu.net. pinkje.ripe.net 3600 IN A 193.0.1.162 host25.ripe.net 2600 IN A 193.0.3.25

  32. Resource Record: SOA and NS • The SOA and NS records are used to provide information about the DNS itself. • The NS indicates where information about a given zone can be found: • The SOA record provides information about the start of authority, i.e. the top of the zone, also called the APEX. ripe.net 7200 IN NS ns.ripe.net. ripe.net 7200 IN NS ns.eu.net.

  33. Master server Contact address Version number Timing parameter Resource Record: SOA net. 3600 IN SOA A.GTLD-SERVERS.net. nstld.verisign-grs.com. ( 2002021301 ; serial 30M ; refresh 15M ; retry 1W ; expiry 1D ) ; neg. answ. ttl

  34. Concept: TTL and other Timers • TTL is a timer used in caches • An indication for how long the data may be reused • Data that is expected to be ‘stable’ can have high TTLs • SOA timers are used for maintaining consistency between primary and secondary servers

  35. Upload of zone data is local policy Places where DNS data lives Changes in DNS do not propagate instantly! Slave Might take up to refresh to get data from master Not going to net if TTL>0 Cache server Master Registry DB Slave server

  36. To remember... • Multiple authoritative servers to distribute load and risk: • Put your name servers apart from each other • Caches to reduce load to authoritative servers and reduce response times • SOA timers and TTL need to be tuned to needs of zone. Stable data: higher numbers

  37. What have we learnedWhat are we about to learn • We learned about the architecture: • resolvers, • caching forwarders, • authoritative servers, • timing parameters • We continue writing a zone file

  38. Writing a zone file. • Zone file is written by the zone administator • Zone file is read by the master server and it’s content is replicated to slave servers • What is in the zone file will end up in the database • Because of timing issues it might take some time before the data is actually visible at the client side.

  39. First attempt • The ‘header’ of the zone file • Start with a SOA record • Include authoritative name servers and, if needed, glue • Add other information • Add other RRs • Delegate to other zones

  40. Comments Line break The SOA record • bill.manning@ep.net  bill\.manning.ep.net • Should be the tech contact email • Serial number: 32bit circular arithmetic • People often use date format • To be increased after editing • The timers above qualify as reasonable (for some areas) ep.net. 3600 IN SOA flag.ep.net. ( bill\.manning.ep.net. 2002021301 ; serial 1h ; refresh 30M ; retry 1W ; expiry 3600 ) ; neg. answ. ttl

  41. Authoritative NS records and related A records • NS record for all the authoritative servers. • They need to carry the zone at the moment you publish • A records only for “in-zone” name servers. • Delegating NS records might have glue associated. secret-wg.org. 3600 IN NS bert.secret-wg.org. secret-wg.org. 3600 IN NS NS2.secret-wg.org. bert.secret-wg.org. 3600 IN A 193.0.0.4 NS2.secret-wg.org. 3600 IN A 193.0.0.202

  42. Other ‘APEX’ data Examples: • MX records for mail (see next slide) • Location records secret-wg.org. 3600 IN MX 50 mailhost.secret-wg.org. secret-wg.org. 3600 IN MX 150 mailhost2.secret-wg.org. secret-wg.org. 3600 IN LOC ( 52 21 23.0 N 04 57 05.5 E 0m 100m 100m 100m ) secret-wg.org. 3600 IN TXT “Demonstration and test zone” TXT records A records KEY records for dnssec

  43. Intermezzo: MX record • SMTP (simple mail transfer protocol) uses MX records to find the destination mail server. • If a mail is sent to olaf@ripe.net the sending mail agent looks up ‘ripe.net MX’ • MX record contains mail relays with priority. • The lower the number the higher the priority. • Don’t add MX records without having a mail relay configured.

  44. Other data in the zone • Add all the other data to your zone file. • Some notes on notation. • Note the fully qualified domain name including trailing dot. • Note TTL and CLASS localhost.secret-wg.org. 3600 IN A 127.0.0.1 bert.secret-wg.org. 4500 IN A 193.0.0.4 www.secret-wg.org. 3600 IN CNAME bert.secret-wg.org.

  45. Zone file format short cutsnice formatting secret-wg.org. 3600 IN SOA bert.secret-wg.org. ( olaf\.kolkman.ripe.net. 2002021301 ; serial 1h ; refresh 30M ; retry 1W ; expiry 3600 ) ; neg. answ. Ttl secret-wg.org. 3600 IN NS bert.secret-wg.org. secret-wg.org. 3600 IN NS NS2.secret-wg.org. secret-wg.org. 3600 IN MX 50 mailhost.secret-wg.org. secret-wg.org. 3600 IN MX 150 mailhost2.secret-wg.org. secret-wg.org. 3600 IN LOC ( 52 21 23.0 N 04 57 05.5 E 0m 100m 100m 100m ) secret-wg.org. 3600 IN TXT “Demonstration and test zone” bert.secret-wg.org. 4500 IN A 193.0.0.4 NS2.secret-wg.org. 3600 IN A 193.0.0.202 localhost.secret-wg.org. 3600 IN A 127.0.0.1 bert.secret-wg.org. 3600 IN A 193.0.0.4 www.secret-wg.org. 3600 IN CNAME bert.secret-wg.org.

  46. Zone file format short cuts: repeating last name secret-wg.org. 3600 IN SOA bert.secret-wg.org. ( olaf\.kolkman.ripe.net. 2002021301 ; serial 1h ; refresh 30M ; retry 1W ; expiry 3600 ) ; neg. answ. Ttl 3600 IN NS bert.secret-wg.org. 3600 IN NS NS2.secret-wg.org. 3600 IN MX 50 mailhost.secret-wg.org. 3600 IN MX 150 mailhost2.secret-wg.org. 3600 IN LOC ( 52 21 23.0 N 04 57 05.5 E 0m 100m 100m 100m ) 3600 IN TXT “Demonstration and test zone” bert.secret-wg.org. 3600 IN A 193.0.0.4 NS2.secret-wg.org. 3600 IN A 193.0.0.202 localhost.secret-wg.org. 4500 IN A 127.0.0.1 bert.secret-wg.org. 3600 IN A 193.0.0.4 www.secret-wg.org. 3600 IN CNAME bert.secret-wg.org.

  47. Zone file format short cuts: default TTL $TTL 3600 ; Default TTL directive secret-wg.org. IN SOA bert.secret-wg.org. ( olaf\.kolkman.ripe.net. 2002021301 ; serial 1h ; refresh 30M ; retry 1W ; expiry 3600 ) ; neg. answ. Ttl IN NS bert.secret-wg.org. IN NS NS2.secret-wg.org. IN MX 50 mailhost.secret-wg.org. IN MX 150 mailhost2.secret-wg.org. IN LOC ( 52 21 23.0 N 04 57 05.5 E 0m 100m 100m 100m ) IN TXT “Demonstration and test zone” bert.secret-wg.org. IN A 193.0.0.4 NS2.secret-wg.org. IN A 193.0.0.202 localhost.secret-wg.org. IN A 127.0.0.1 bert.secret-wg.org. 4500 IN A 193.0.0.4 www.secret-wg.org. IN CNAME bert.secret-wg.org.

  48. Zone file format short cuts: ORIGIN $TTL 3600 ; Default TTL directive $ORIGIN secret-wg.org. @ IN SOA bert ( olaf\.kolkman.ripe.net. 2002021301 ; serial 1h ; refresh 30M ; retry 1W ; expiry 3600 ) ; neg. answ. Ttl IN NS bert IN NS NS2 IN MX 50 mailhost IN MX 150 mailhost2 IN LOC ( 52 21 23.0 N 04 57 05.5 E 0m 100m 100m 100m ) IN TXT “Demonstration and test zone” bert IN A 193.0.0.4 NS2 IN A 193.0.0.202 localhost IN A 127.0.0.1 bert 4500 IN A 193.0.0.4 www IN CNAME bert

  49. com net edu google • sun • • ripe tislabs moon ripe.net zone isi • • disi www www ftp • disi.ripe.net zone ws2 ws1 Delegating a zone(becoming a parent) • Delegate authority for a sub domain to another party (splitting of disi.ripe.net from ripe.net)

More Related