Domain Name System (DNS) Joe Abley AfNOG Workshop, AIS 2014, Djibouti Session-1: Fundamentals.

Slides:



Advertisements
Similar presentations
Domain Name System (DNS) Adapted from a presentation by Ayitey Bulley DNS Fundamentals.
Advertisements

Sergei Komarov. DNS  Mechanism for IP hostname resolution  Globally distributed database  Hierarchical structure  Comprised of three components.
Domain Name System. DNS is a client/server protocol which provides Name to IP Address Resolution.
DNS Session 4: Delegation and reverse DNS Joe Abley AfNOG 2006 workshop.
Introduction to the DNS AfCHIX 2011 Blantyre, Malawi.
1 DNS. 2 BIND DNS –Resolve names to IP address –Resolve IP address to names (reverse DNS) BIND –Berkeley Internet Name Domain system Version 4 is still.
The Domain Name System. CeylonLinux DNS concepts using BIND 2 Hostnames IP Addresses are great for computers –IP address includes information used for.
Domain Name System (DNS) Network Information Center (NIC) : HOSTS.TXT.
Domain Name System: DNS
MCTS Guide to Microsoft Windows Server 2008 Network Infrastructure Configuration Chapter 5 Introduction to DNS in Windows Server 2008.
70-293: MCSE Guide to Planning a Microsoft Windows Server 2003 Network, Enhanced Chapter 7: Planning a DNS Strategy.
TCP/IP Protocol Suite 1 Copyright © The McGraw-Hill Companies, Inc. Permission required for reproduction or display. Chapter 19 Domain Name System (DNS)
CPSC 441: DNS1 Instructor: Anirban Mahanti Office: ICT Class Location: ICT 121 Lectures: MWF 12:00 – 12:50 Notes derived.
TCP/IP Protocol Suite 1 Chapter 17 Upon completion you will be able to: Domain Name System: DNS Understand how the DNS is organized Know the domains in.
Presented by Neeta Jain CISC 856 TCP/IP and Upper Layer Protocols RFC 1034 & RFC 1035.
Domain Name Services Oakton Community College CIS 238.
11.1 © 2004 Pearson Education, Inc. Exam Managing and Maintaining a Microsoft® Windows® Server 2003 Environment Lesson 11: Introducing WINS, DNS,
Domain Name System (DNS) Ayitey Bulley Session-1: Fundamentals.
NET0183 Networks and Communications Lecture 25 DNS Domain Name System 8/25/20091 NET0183 Networks and Communications by Dr Andy Brooks.
Tony Kombol ITIS Who knows this? Who controls this? DNS!
1 Domain Name System (DNS). 2 DNS: Domain Name System Internet hosts: – IP address (32 bit) - used for addressing datagrams – “name”, e.g.,
Netprog: DNS and name lookups1 Address Conversion Functions and The Domain Name System Refs: Chapter 9 RFC 1034 RFC 1035.
Chapter 16 – DNS. DNS Domain Name Service This service allows client machines to resolve computer names (domain names) to IP addresses DNS works at the.
Microsoft Windows Server 2003 TCP/IP Protocols and Services Technical Reference Slide: 1 Lesson 17 Domain Name System (DNS)
Petrozavodsk State University, Alex Moschevikin, 2003NET TECHNOLOGIES Domain Name System HISTORY File hosts (the size of Internet became more than 1000.
DNS: Domain Name System
1 DNS: Domain Name System People: many identifiers: m SSN, name, Passport # Internet hosts, routers: m IP address (32 bit) - used for addressing datagrams.
14 DNS : The Domain Name System. 14 Introduction - Problem Computers are used to work with numbers Humans are used to work with names ==> IP addresses.
October 15, 2002Serguei A. Mokhov, 1 Intro to DNS SOEN321 - Information Systems Security.
Chapter 17 Domain Name System
DNS Related Commands Sayed Ahmed Computer Engineering, BUET, Bangladesh (Graduated on 2001 ) MSc, Computer Science, U of Manitoba, Canada
October 8, 2015 University of Tulsa - Center for Information Security Microsoft Windows 2000 DNS October 8, 2015.
Chapter 16 – The Domain Name System (DNS) Presented by Shari Holstege Tuesday, June 18, 2002.
Module 8 DNS Tools & Diagnostics. Objectives Understand dig and nslookup Understand BIND toolset Understand BIND logs Understand wire level messages.
Netprog: DNS and name lookups1 Address Conversion Functions and The Domain Name System Refs: Chapter 9 RFC 1034 RFC 1035.
Internet and Intranet Protocols and Applications Lecture 5 Application Protocols: DNS February 20, 2002 Joseph Conron Computer Science Department New York.
1 Kyung Hee University Chapter 18 Domain Name System.
Tony Kombol ITIS DNS! overview history features architecture records name server resolver dnssec.
Domain Name System Refs: Chapter 9 RFC 1034 RFC 1035.
CPSC 441: DNS 1. DNS: Domain Name System Internet hosts: m IP address (32 bit) - used for addressing datagrams m “name”, e.g., - used by.
Configuring Name Resolution and Additional Services Lesson 12.
Domain Name System (DNS). DNS Server Service Overview of Domain Name System What Is a Domain Namespace? Standards for DNS Naming.
EE 122: Lecture 20 (Domain Name Server - DNS) Ion Stoica Nov 15, 2001 (* based on the some on-line slides of J. Kurose & K. Rose and of Raj Jain)
TCP/IP Protocol Suite 1 Copyright © The McGraw-Hill Companies, Inc. Permission required for reproduction or display. Chapter 19 Domain Name System (DNS)
Module 8 DNS Tools & Diagnostics. Dig always available with BIND (*nix) and windows Nslookup available on windows and *nix Dig on windows – unpack zip,
DNS DNS overview DNS operation DNS zones. DNS Overview Name to IP address lookup service based on Domain Names Some DNS servers hold name and address.
Linux Operations and Administration
AfNOG-2003 Domain Name System (DNS) Ayitey Bulley
Web Server Administration Chapter 4 Name Resolution.
1 CMPT 471 Networking II DNS © Janice Regan,
TCP/IP Protocol Suite 1 Chapter 17 Upon completion you will be able to: Domain Name System: DNS Understand how the DNS is organized Know the domains in.
COMP 431 Internet Services & Protocols
Internet Naming Service: DNS* Chapter 5. The Name Space The name space is the structure of the DNS database –An inverted tree with the root node at the.
Basics of the Domain Name System (DNS) By : AMMY- DRISS Mohamed Amine KADDARI Zakaria MAHMOUDI Soufiane Oujda Med I University National College of Applied.
Domain Name System (DNS) Ayitey Bulley extended by Phil Regnauld DNS Fundamentals AfNOG 2006.
Track E0 AfNOG workshop April Abuja, Nigeria Introduction to the DNS.
1 CMPT 471 Networking II DNS © Janice Regan,
DNS and Inbound Load Balancing
Understand Names Resolution
Domain Name System (DNS)
Domain Name System (DNS)
Session-1: Fundamentals
Introduction to the DNS
Domain Name System Tony Kombol ITIS 3110.
Module 5: Resolving Host Names by Using Domain Name System (DNS)
Domain Name System (DNS)
DNS: Domain Name System
Domain Name System Refs: Chapter 9 RFC 1034 RFC 1035.
DNS : Domain Name System
Domain Name System: DNS
Presentation transcript:

Domain Name System (DNS) Joe Abley AfNOG Workshop, AIS 2014, Djibouti Session-1: Fundamentals

Computers use IP addresses. Why do we need names? Names are easier for people to remember Computers may be moved between networks, in which case their IP addresses will change. Services might move between computers, in which case their IP addresses will change.

The old solution: HOSTS.TXT A centrally-maintained file, distributed to all hosts on the Internet SPARKY UCB-MAILGATE FTPHOST etc This feature still exists: /etc/hosts (UNIX) c:\windows\hosts

hosts.txt does not scale ✗ Huge file (traffic and load) ✗ Name collisions (name uniqueness) ✗ Consistency ✗ Always out of date ✗ Single point of Administration ✗ Did not scale well

The Domain Name System was born DNS is a distributed database for holding name to IP address (and other) information Distributed: – Shares the Administration – Shares the Load Robustness and improved performance achieved through – replication – and caching Employs a client-server architecture A critical piece of the Internet's infrastructure

DNS is Hierarchical. (root) maorg com DNS Database / (root) etc usr bin Unix Filesystem Forms a tree structure ac.ma emi.ac.ma afnog.orgnsrc.org yahoo.com ws.afnog.org usr/localusr/sbin/etc/rc.d usr/local/src

DNS is Hierarchical (contd.) Globally unique names Administered in zones (parts of the tree) You can give away ("delegate") control of part of the tree underneath you Example: – org on one set of nameservers – afnog.org on a different set – ws.afnog.org on a different set

Domain Names are (almost) unlimited Max 255 characters total length Max 63 characters in each label – RFC 1034, RFC 1035 If a domain name is being used as a host name, you should abide by some restrictions – RFC 952 (old!) – a-z 0-9 and minus (-) only – No underscores ( _ )

Using the DNS A Domain Name (like is the KEY to look up information The result is one or more RESOURCE RECORDS (RRs) There are different RRs for different types of information You can ask for the specific type you want, or ask for "any" RRs associated with the domain name

Commonly seen Resource Records (RRs) A (address): map hostname to IPv4 address AAAA (quad A): map a hostname to IPv6 address PTR (pointer): map IP address to hostname MX (mail exchanger): where to deliver mail for CNAME (canonical name): map alternative hostname to real hostname TXT (text): any descriptive text NS (name server), SOA (start of authority): used for delegation and management of the DNS itself

A Simple Example Query: Query type: A Result: IN A In this case a single RR is found, but in general, multiple RRs may be returned. – (IN is the "class" for INTERNET use of the DNS)

Possible results from a Query POSITIVE (“NOERROR”) – the name exists, and has zero or more RRs associated with it NEGATIVE (“NXDOMAIN”) – the name does not exist SERVER FAILURE (“SERVFAIL”) – server is having bad hair day FORMAT ERROR (“FORMERR”) – the query you sent was broken in some way REFUSED (“REFUSED”) – not allowed to query the server

How do you use an IP address as the key for a DNS query Convert the IP address to dotted-quad Reverse the four parts Add ".in-addr.arpa." to the end; special domain reserved for this purpose e.g. to find name for Domain name: in-addr.arpa. Query Type: PTR Result:ashanti.gh.com. Known as a "reverse DNS lookup" (because we are looking up the name for an IP address, rather than the IP address for a name)

? Any Questions?

DNS is a Client-Server application (Of course - it runs across a network) Requests and responses are most frequently carried in UDP packets, port 53 DNS can also use TCP transport, port 53 – for very large responses e.g. zone transfers – because you want to exchange more than one query/response on a single session – because a response you received told you to with TC=1 – because UDP is being aggressively rate-limited or blocked (e.g. to mitigate a reflection attack)

There are three roles involved in DNS Stub Resolver Caching Resolver Authoritative Nameserver Application e.g. web browser

Three roles in DNS STUB RESOLVER – Takes request from application, formats it into UDP packet, sends to recursive resolver RECURSIVE RESOLVER – Returns the answer if already known – Otherwise searches for an authoritative server which has the information – Caches the result for future queries AUTHORITATIVE NAMESERVER – Contains the actual information published in the DNS by the domain owner

Three roles in DNS The SAME protocol is used for stub resolver and resolver auth nameserver It is possible to configure a single name server as both a resolver and an authoritative server But it still performs only one role for each incoming query Common but NOT RECOMMENDED to configure in this way (we will see why later).

ROLE 1: THE STUB RESOLVER A piece of software which formats a DNS request into a DNS message, sends it to a resolver, and decodes the response when it arrives Usually a shared library (e.g. libresolv.so under Unix) because so many applications need it EVERY host needs a stub resolver - e.g. every Windows workstation has one

How does the stub resolver find a recursive nameserver? It has to be explicitly configured (statically, or via DHCP etc) Must be configured with the IP ADDRESS of a cache (why not name?) Good idea to configure more than one cache, in case the first one fails

How do you choose which recursive resolver(s) to configure? Must have PERMISSION to use it – e.g. cache at your ISP, or your own, or a reliably public one Prefer a nearby cache – Minimises round-trip time and packet loss – Can reduce traffic on your external link, since often the cache can answer without contacting other servers Prefer a reliable cache – Perhaps your own?

Stub resolvers can be configured with default domain(s) If "foo.bar" fails, then retry query as "foo.bar.mydomain.com" Can save typing but adds confusion May generate extra unnecessary traffic Usually best avoided

Example: Unix stub resolver configuration /etc/resolv.conf search sse.ws.afnog.org nameserver nameserver That's all you need to configure a resolver

Testing DNS Just put " in a web browser? Why is this not a good test?

Testing DNS with "dig" "dig" is a program which just makes DNS queries and displays the results Better than "nslookup", "host" because it shows the raw information in full dig ws.afnog.org. -- defaults to query type "A" dig afnog.org. mx -- specified query type afnog.org. mx -- send to particular cache (overrides /etc/resolv.conf)

The trailing dot # dig ws.afnog.org. ● Prevents any default domain being appended ● Get into the habit of using it always when testing DNS – only on domain names, not IP addresses or addresses

/usr/home/field]$ downloads.dns.gh. a ; > DiG downloads.dns.gh. a ; (1 server found) ;; global options: printcmd ;; Got answer: ;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: ;; flags: qr aa rd ra; QUERY: 1, ANSWER: 2, AUTHORITY: 3, ADDITIONAL: 0 ;; QUESTION SECTION: ;downloads.dns.gh. IN A ;; ANSWER SECTION: downloads.dns.gh IN CNAME zoe.dns.gh. zoe.dns.gh IN A ;; AUTHORITY SECTION: dns.gh IN NS zoe.dns.gh. dns.gh IN NS mantse.gh.com. dns.gh IN NS snshq902.ghanatel.com.gh. ;; Query time: 275 msec ;; SERVER: #53( ) ;; WHEN: Sat May 24 00:17: ;; MSG SIZE rcvd: 145

Understanding output from dig STATUS – NOERROR: 0 or more RRs returned – NXDOMAIN: non-existent domain – SERVFAIL: cache could not locate answer – REFUSED: query not available on cache server FLAGS – AA: Authoritative answer (not from cache) – You can ignore the others QR: Query/Response (1 = Response) RD: Recursion Desired RA: Recursion Available ANSWER: number of RRs in answer

Understanding output from dig Answer section (RRs requested) – Each record has a Time To Live (TTL) – Says how long the cache will keep it Authority section – Which nameservers are authoritative for this domain Additional section – More RRs (typically IP addresses for the authoritative nameservers) Total query time Check which server gave the response! – If you make a typing error, the query may go to a default server

Practical Exercise Configure Unix resolver Issue DNS queries using 'dig' Use tcpdump to show queries being sent to cache