Chapter 8 Communication Networks and Services

The TCP/IP Architecture The IPv6 Transport Layer Protocols Internet Routing Protocols Multicast Routing DHCP, NAT, and Mobile IP

1 Chapter 8 Communication Networks and Services

The TCP/IP Architecture

2 TCP/IP Protocol Suite

HTTP SMTP DNS RTP Distributed applications Reliable User stream TCP UDP datagram service service

Best-effort IP connectionless (ICMP, ARP) packet transfer

Network Network Network Interface 1 Interface 2 Interface 3 3 Diverse network technologies Internet Names & Addresses

Internet Names Internet Addresses z Each host has a unique name z Each host has globally unique z Independent of physical logical 32 bit IP address location z Separate address for each z Facilitate memorization by humans physical connection to a network z z Domain Name Routing decision is done based on destination IP address z Organization under single administrative unit z IP address has two parts: z Host Name z netid and hostid z Name given to host z netid unique computer z netid facilitates routing z User Name z Dotted Decimal Notation: z Name assigned to user int1.int2.int3.int4 [email protected] (intj = jth octet) 128.100.10.13 DNS resolves IP name to IP address 4 Physical Addresses z LANs (and other networks) assign physical addresses to the physical attachment to the network z The network uses its own address to transfer packets or frames to the appropriate destination z IP address needs to be resolved to physical address at each IP network interface z Example: uses 48-bit addresses z Each Ethernet network interface card (NIC) has globally unique Medium Access Control (MAC) or physical address z First 24 bits identify NIC manufacturer; second 24 bits are serial number z 00:90:27:96:68:07 12 hex numbers

Intel 5 Encapsulation

TCP Header contains source & destination HTTP Request port numbers

IP Header contains source and destination TCP IP addresses; header HTTP Request transport protocol type

Ethernet Header contains IP TCP source & destination MAC HTTP Request addresses; header header network protocol type

Ethernet IP TCP FCS header header header HTTP Request 6 Chapter 8 Communication Networks and Services

The Internet Protocol

7 Internet Protocol z Provides best effort, connectionless packet delivery z motivated by need to keep routers simple and by adaptibility to failure of network elements z packets may be lost, out of order, or even duplicated z higher layer protocols must deal with these, if necessary z RFCs 791, 950, 919, 922, and 2474. z IP is part of Internet STD number 5, which also includes: z Internet Control Message Protocol (ICMP), RFC 792 z Internet Group Management Protocol (IGMP), RFC 1112

8 IP Packet Header

0 4 8 16 19 24 31

Version IHL Type of Service Total Length

Identification Flags Fragment Offset

Time to Live Protocol Header Checksum

Source IP Address

Destination IP Address

Options Padding

z Minimum 20 bytes z Up to 40 bytes in options fields

9 IP Packet Header

0 4 8 16 19 24 31

Version IHL Type of Service Total Length

Identification Flags Fragment Offset

Time to Live Protocol Header Checksum

Source IP Address

Destination IP Address

Options Padding

Version: current IP version is 4. Internet header length (IHL): length of the header in 32-bit words. Type of service (TOS): traditionally priority of packet at each router. Recent Differentiated Services redefines TOS field to include other services besides best 10 effort. IP Packet Header

0 4 8 16 19 24 31

Version IHL Type of Service Total Length

Identification Flags Fragment Offset

Time to Live Protocol Header Checksum

Source IP Address

Destination IP Address

Options Padding

Total length: number of bytes of the IP packet including header and data, maximum length is 65535 bytes. Identification, Flags, and Fragment Offset: used for fragmentation and reassembly (More on this shortly). 11 IP Packet Header

0 4 8 16 19 24 31

Version IHL Type of Service Total Length

Identification Flags Fragment Offset

Time to Live Protocol Header Checksum

Source IP Address

Destination IP Address

Options Padding

Time to live (TTL): number of hops packet is allowed to traverse in the network. • Each router along the path to the destination decrements this value by one. • If the value reaches zero before the packet reaches the destination, the router discards the packet and sends an error message back to the source. 12 IP Packet Header

0 4 8 16 19 24 31

Version IHL Type of Service Total Length

Identification Flags Fragment Offset

Time to Live Protocol Header Checksum

Source IP Address

Destination IP Address

Options Padding

Protocol: specifies upper-layer protocol that is to receive IP data at the destination. Examples include TCP (protocol = 6), UDP (protocol = 17), and ICMP (protocol = 1). Header checksum: verifies the integrity of the IP header. Source IP address and destination IP address: contain the addresses of the 13 source and destination hosts. IP Packet Header

0 4 8 16 19 24 31

Version IHL Type of Service Total Length

Identification Flags Fragment Offset

Time to Live Protocol Header Checksum

Source IP Address

Destination IP Address

Options Padding

Options: Variable length field, allows packet to request special features such as security level, route to be taken by the packet, and timestamp at each router. Detailed descriptions of these options can be found in [RFC 791]. Padding: This field is used to make the header a multiple of 32-bit words. 14 Example of IP Header

15 Header Checksum

z IP header uses check bits to detect errors in the header z A checksum is calculated for header contents z Checksum recalculated at every router, so algorithm selected for ease of implementation in software z Let header consist of L, 16-bit words,

b0, b1, b2, ..., bL-1 z The algorithm appends a 16-bit checksum bL

16 Checksum Calculation

The checksum bL is calculated as follows: z Treating each 16-bit word as an integer, find 15 x = b0 + b1 + b2+ ...+ bL-1 modulo 2 -1 z The checksum is then given by: 15 bL = - x modulo 2 -1 z This is the 16-bit 1’s complement sum of the b’s z If checksum is 0, use all 1’s representation (all zeros reserved to indicate checksum was not calculated) z Thus, the headers must satisfy the following pattern: 15 0 = b0 + b1 + b2+ ...+ bL-1 + bL modulo 2 -1

17 IP Header Processing

1. Compute header checksum for correctness and check that fields in header (e.g. version and total length) contain valid values 2. Consult routing table to determine next 3. Change fields that require updating (TTL, header checksum)

18 IP Addressing z RFC 1166 z Each host on Internet has unique 32 bit IP address z Each address has two parts: netid and hostid z netid unique & administered by z American Registry for Internet Numbers (ARIN) z Reseaux IP Europeens (RIPE) z Asia Pacific Network Information Centre (APNIC) z Facilitates routing z A separate address is required for each physical connection of a host to a network; “multi-homed” hosts z Dotted-Decimal Notation: int1.int2.int3.int4 where intj = integer value of jth octet IP address of 10000000 10000111 01000100 00000101

is 128.135.68.5 in dotted-decimal notation 19 Classful Addresses Class A 7 bits 24 bits 0 netid hostid • 126 networks with up to 16 million hosts 1.0.0.0 to 127.255.255.255

Class B 14 bits 16 bits 1 0 netid hostid • 16,382 networks with up to 64,000 hosts 128.0.0.0 to 191.255.255.255

Class C 22 bits 8 bits 1 1 0 netid hostid • 2 million networks with up to 254 hosts 192.0.0.0 to 223.255.255.255

20 Class D 28 bits 1 1 1 0 multicast address 224.0.0.0 to 239.255.255.255

z Up to 250 million multicast groups at the same time z Permanent group addresses z All systems in LAN; All routers in LAN; z All OSPF routers on LAN; All designated OSPF routers on a LAN, etc. z Temporary groups addresses created as needed z Special multicast routers

21 Reserved Host IDs (all 0s & 1s)

Internet address used to refer to network has hostid set to all 0s

this host 0 0 0 0 0 0 (used when booting up)

a host 0 0 0 host in this network

Broadcast address has hostid set to all 1s broadcast on 1 1 1 1 1 1 local network

broadcast on netid 1 1 1 1 1 1 1 distant network22 Private IP Addresses z Specific ranges of IP addresses set aside for use in private networks (RFC 1918) z Use restricted to private internets; routers in public Internet discard packets with these addresses z Range 1: 10.0.0.0 to 10.255.255.255 z Range 2: 172.16.0.0 to 172.31.255.255 z Range 3: 192.168.0.0 to 192.168.255.255 z Network Address Translation (NAT) used to convert between private & global IP

addresses 23 Example of IP Addressing

128.135.40.1 128.140.5.40 Interface Interface H H Address is Address is 128.135.10.2 128.140.5.35

Network Network R 128.135.0.0 128.140.0.0

H H H 128.135.10.20 128.135.10.21 128.140.5.36

Address with host ID=all 0s refers to the network R = router Address with host ID=all 1s refers to a broadcast packet H = host24 Subnet Addressing z Subnet addressing introduces another hierarchical level z Transparent to remote networks z Simplifies management of multiplicity of LANs z Masking used to find subnet number

Original 1 0 Net ID Host ID address

Subnetted address 1 0 Net ID Subnet ID Host ID

25 Subnetting Example z Organization has Class B address (16 host ID bits) with network ID: 150.100.0.0 z Create subnets with up to 100 hosts each z 7 bits sufficient for each subnet z 16-7=9 bits for subnet ID z Apply subnet mask to IP addresses to find corresponding subnet z Example: Find subnet for 150.100.12.176 z IP add = 10010110 01100100 00001100 10110000 z Mask = 11111111 11111111 11111111 10000000 z AND = 10010110 01100100 00001100 10000000 z Subnet = 150.100.12.128 z Subnet address used by routers within organization

26 Subnet Example

H1 H2 150.100.12.154 150.100.12.176 150.100.12.128 150.100.12.129 150.100.0.1 R1 To the rest of H3 H4 the Internet 150.100.12.4 150.100.12.24 150.100.12.55

150.100.12.0 150.100.12.1 R2 H5

150.100.15.54 150.100.15.11

150.100.15.0

27 Routing with Subnetworks z IP layer in hosts and routers maintain a routing table z Originating host: To send an IP packet, consult routing table z If destination host is in same network, send packet directly using appropriate network interface z Otherwise, send packet indirectly; typically, routing table indicates a default router z Router: Examine IP destination address in arriving packet z If dest IP address not own, router consults routing table to determine next-hop and associated network interface & forwards packet

28 Routing Table z Each row in routing table z Routing table search order contains: & action z Destination IP address z Complete destination z IP address of next-hop address; send as per next- router hop & G flag z Physical address z Destination network ID; send as per next-hop & G z Statistics information flag z Flags z Default router entry; send z H=1 (0) indicates route is as per next-hop to a host (network) z Declare packet z G=1 (0) indicates route is to a router (directly undeliverable; send ICMP connected destination) “host unreachable error” packet to originating host

29 Example: Host H5 sends packet to host H2 H1 H2 150.100.12.154 150.100.12.176 150.100.12.128 150.100.12.129 150.100.0.1 R1 To the rest of H3 H4 the Internet 150.100.12.4 150.100.12.24 150.100.12.55

150.100.12.0 150.100.12.1 R2 H5

150.100.15.54 150.100.15.11 Routing Table at H5 150.100.15.0 Destination Next-Hop Flags Net I/F 127.0.0.1 127.0.0.1 H lo0 150.100.12.176 default 150.100.15.54 G emd0 30 150.100.15.0 150.100.15.11 emd0 Example: Host H5 sends packet to host H2 H1 H2 150.100.12.154 150.100.12.176 150.100.12.128 150.100.12.129 150.100.0.1 R1 To the rest of H3 H4 the Internet 150.100.12.4 150.100.12.24 150.100.12.55

150.100.12.0 150.100.12.1 150.100.12.176 Routing Table at R2 R2 H5 150.100.15.54 150.100.15.11 Destination Next-Hop Flags Net I/F 150.100.15.0 127.0.0.1 127.0.0.1 H lo0 default 150.100.12.4 G emd0 150.100.15.0 150.100.15.54 emd1 31 150.100.12.0 150.100.12.1 emd0 Example: Host H5 sends packet to host H2 H1 H2 150.100.12.154 150.100.12.176 150.100.12.128 150.100.12.129 150.100.12.176 150.100.0.1 R1 To the rest of H3 H4 the Internet 150.100.12.4 150.100.12.24 150.100.12.55

150.100.12.0 150.100.12.1 Routing Table at R1 R2 H5 150.100.15.54 150.100.15.11 Destination Next-Hop Flags Net I/F 150.100.15.0 127.0.0.1 127.0.0.1 H lo0 150.100.12.176 150.100.12.176 emd0 150.100.12.0 150.100.12.4 emd1 32 150.100.15.0 150.100.12.1 G emd1 IP Address Problems

z In the 1990, two problems became apparent z IP addresses were being exhausted z IP routing tables were growing very large z IP Address Exhaustion z Class A, B, and C address structure inefficient z Class B too large for most organizations, but future proof z Class C too small z Rate of class B allocation implied exhaustion by 1994 z IP routing table size z Growth in number of networks in Internet reflected in # of table entries z From 1991 to 1995, routing tables doubled in size every 10 months z Stress on router processing power and memory allocation z Short-term solution: z Classless Interdomain Routing (CIDR), RFC 1518 z New allocation policy (RFC 2050) z Private IP Addresses set aside for intranets z Long-term solution: IPv6 with much bigger address space

33 Classless Inter-Domain Routing

z CIDR deals with Routing Table Explosion Problem z Networks represented by prefix and mask z Pre-CIDR: Network with range of 16 contiguous class C blocks requires 16 entries z Post-CIDR: Network with range of 16 contiguous class C blocks requires 1 entry z Solution: Route according to prefix of address, not class z Routing table entry has z Example: 192.32.136.0/21 z 11000000 00100000 10001000 00000001 min address z 11111111 11111111 11111------mask z 11000000 00100000 10001------IP prefix z 11000000 00100000 10001111 11111110 max address z 11111111 11111111 11111------mask z 11000000 00100000 10001------same IP prefix 34 CIDR Allocation Principles (RFC 1518-1520) z IP address assignment reflects physical topology of network z Network topology follows continental/national boundaries z IP addresses should be assigned on this basis z Transit routing domains (TRDs) have unique IP prefix z carry traffic between routing domains z interconnected non-hierarchically, cross national boundaries z Most routing domains single-homed: attached to a single TRD z Such domains assigned addresses with TRD's IP prefix z All of the addresses attached to a TRD aggregated into 1table entry z Implementation primarily through BGPv4 (RFC 1520)

35 Longest Prefix Match z CIDR impacts routing & forwarding z Routing tables and routing protocols must carry IP address and mask z Multiple entries may match a given IP destination address z Example: Routing table may contain z 205.100.0.0/22 which corresponds to a given supernet z 205.100.0.0/20 which results from aggregation of a larger number of destinations into a supernet z Packet must be routed using the more specific route, that is, the longest prefix match z Several fast longest-prefix matching algorithms are available 36 Address Resolution Protocol Although IP address identifies a host, the packet is physically delivered by an underlying network (e.g., Ethernet) which uses its own physical address (MAC address in Ethernet). How to map an IP address to a physical address?

H1 wants to learn physical address of H3 -> broadcasts an ARP request

H1 H2 H3 H4

150.100.76.20 150.100.76.21 150.100.76.22 150.100.76.23

ARP request (what is the MAC address of 150.100.76.22?) Every host receives the request, but only H3 reply with its physical address

H1 H2 H3 H4

ARP response (my MAC address is 08:00:5a:3b:94) 37 Example of ARP

38 Fragmentation and Reassembly

• Identification identifies a particular packet • Flags = (unused, don’t fragment/DF, more fragment/MF) • Fragment offset identifies the location of a fragment within a packet

Reassemble at destination Source Router Destination Fragment at source Fragment IP IP at router

Network Network

39 Example: Fragmenting a Packet z A packet is to be forwarded to a network with MTU of 576 bytes. The packet has an IP header of 20 bytes and a data part of 1484 bytes. and of each fragment. z Maximum data length per fragment = 576 - 20 = 556 bytes. z We set maximum data length to 552 bytes to get multiple of 8.

Total Id MF Fragment Length Offset Original 1504 x 0 0 packet Fragment 1 572 x 1 0 Fragment 2 572 x 1 69 Fragment 3 400 x 0 138 40 Internet Control Message Protocol (ICMP) z RFC 792; Encapsulated in IP packet (protocl type = 1) z Handles error and control messages z If router cannot deliver or forward a packet, it sends an ICMP “host unreachable” message to the source z If router receives packet that should have been sent to another router, it sends an ICMP “redirect” message to the sender; Sender modifies its routing table z ICMP “router discovery” messages allow host to learn about routers in its network and to initialize and update its routing tables z ICMP echo request and reply facilitate diagnostic and used in “ping”

41 ICMP Basic Error Message Format

0 8 16 31

Type Code Checksum

Unused

IP header and 64 bits of original datagram

z Type of message: some examples z 0 Network Unreachable; 3 Port Unreachable z 1 Host Unreachable 4 Fragmentation needed z 2 Protocol Unreachable 5 Source route failed z 11 Time-exceeded, code=0 if TTL exceeded z Code: purpose of message z IP header & 64 bits of original datagram z To match ICMP message with original data in IP packet 42 Echo Request & Echo Reply Message Format

0 8 16 31

Type Code Checksum

Identifier Sequence number

Data

z Echo request: type=8; Echo reply: type=0 z Destination replies with echo reply by copying data in request onto reply message z Sequence number to match reply to request z ID to distinguish between different sessions using echo services z Used in PING 43 Chapter 8 Communication Networks and Services

IPv6

44 IPv6 z Longer address field: z 128 bits can support up to 3.4 x 1038 hosts z Simplified header format: z Simpler format to speed up processing of each header z All fields are of fixed size z IPv4 vs IPv6 fields: z Same: Version z Dropped: Header length, ID/flags/frag offset, header checksum z Replaced: ƒ Datagram length by Payload length ƒ Protocol type by Next header ƒ TTL by Hop limit ƒ TOS by traffic class

z New: Flow label 45 Other IPv6 Features z Flexible support for options: more efficient and flexible options encoded in optional extension headers z Flow label capability: “flow label” to identify a packet flow that requires a certain QoS z Security: built-in authentication and confidentiality z Large packets: supports payloads that are longer than 64 K bytes, called jumbo payloads. z Fragmentation at source only: source should check the minimum MTU along the path z No checksum field: removed to reduce packet processing time in a router 46 IPv6 Header Format

0 4 12 16 24 31 Version Traffic Class Flow Label Payload Length Next Header Hop Limit

Source Address

Destination Address

z Version field same size, same location z Traffic class to support differentiated services z Flow: sequence of packets from particular source to particular destination for which source requires special handling 47 IPv6 Header Format

0 4 12 16 24 31 Version Traffic Class Flow Label Payload Length Next Header Hop Limit

Source Address

Destination Address

z Payload length: length of data excluding header, up to 65535 B z Next header: type of extension header that follows basic header z Hop limit: # hops packet can travel before being dropped by a router 48 IPv6 Addressing z Address Categories z Unicast: single network interface z Multicast: group of network interfaces, typically at different locations. Packet sent to all. z Anycast: group of network interfaces. Packet sent to only one interface in group, e.g. nearest. z Hexadecimal notation z Groups of 16 bits represented by 4 hex digits z Separated by colons z 4BF5:AA12:0216:FEBC:BA5F:039A:BE9A:2176 z Shortened forms: z 4BF5:0000:0000:0000:BA5F:039A:000A:2176 z To 4BF5:0:0:0:BA5F:39A:A:2176 z To 4BF5::BA5F:39A:A:2176 z Mixed notation: z ::FFFF:128.155.12.198 49 Migration from IPv4 to IPv6 z Gradual transition from IPv4 to IPv6 z Dual IP stacks: routers run IPv4 & IPv6 z Type field used to direct packet to IP version z IPv6 islands can tunnel across IPv4 networks z Encapsulate user packet insider IPv4 packet z Tunnel endpoint at source host, intermediate router, or destination host z Tunneling can be recursive

50 Migration from IPv4 to IPv6

Tunnel head-end Tunnel tail-end Source Destination

Tunnel

(a) IPv6 header IPv6 network IPv4 header IPv6 network IPv4 network

Source Destination Link

(b)

IPv6 network IPv6 network 51 Chapter 8 Communication Networks and Services

Transport Layer Protocols: UDP and TCP

52 Outline z UDP Protocol z TCP Reliable Stream Service z TCP Protocol z TCP Connection Management z TCP Flow Control z TCP Congestion Control

53 UDP z Best effort datagram service z Multiplexing enables sharing of IP datagram service z Simple transmitter & receiver z Connectionless: no handshaking & no connection state z Low header overhead z No flow control, no error control, no congestion control z UDP datagrams can be lost or out-of-order z Applications z multimedia (e.g. RTP) z network services (e.g. DNS, RIP, SNMP)

54 UDP Datagram

0 16 31 z Source and destination port Source Port Destination Port numbers UDP Length UDP Checksum z Client ports are ephemeral z Server ports are well-known Data z Max number is 65,535 z UDP length 0-255 z Total number of bytes in datagram (including header) z Well-known ports z 8 bytes ≤ length ≤ 65,535 256-1023 z UDP Checksum z Less well-known ports z Optionally detects errors in 1024-65536 UDP datagram z Ephemeral client ports 55 UDP Multiplexing

z All UDP datagrams arriving to IP address B and destination port number n are delivered to the same process z Source port number is not used in multiplexing

1 2 ... n 1 2 ... n 1 2 ... n

UDP UDP UDP

IP IP IP B C A 56 UDP Checksum Calculation

0 8 16 31

Source IP Address UDP pseudo- Destination IP Address header

0 0 0 0 0 0 0 0 Protocol = 17 UDP Length z UDP checksum detects for end-to-end errors z Covers pseudoheader followed by UDP datagram z IP addresses included to detect against misdelivery z IP & UDP checksums set to zero during calculation z Pad with 1 byte of zeros if UDP length is odd

57 UDP Receiver Checksum z UDP receiver recalculates the checksum and silently discards the datagram if errors detected z “silently” means no error message is generated z The use of UDP checksums is optional z But hosts are required to have checksums enabled

58 Outline z UDP Protocol z TCP Reliable Stream Service z TCP Protocol z TCP Connection Management z TCP Congestion Control

59 TCP z Reliable byte-stream service z More complex transmitter & receiver z Connection-oriented: full-duplex unicast connection between client & server processes z Connection setup, connection state, connection release z Higher header overhead z Error control, flow control, and congestion control z Higher delay than UDP z Most applications use TCP z HTTP, SMTP, FTP, TELNET, POP3, …

60 Reliable Byte-Stream Service

z Stream Data Transfer z transfers a contiguous stream of bytes across the network, with no indication of boundaries z groups bytes into segments z transmits segments as convenient (Push function defined) z Reliability z error control mechanism to deal with IP transfer impairments

Write 45 bytes Application Write 15 bytes Read 40 bytes Write 20 bytes Read 40 bytes Transport segments

Error Detection buffer & ACKS, sequence # buffer Retransmission 61 Flow Control

z Buffer limitations & speed mismatch can result in loss of data that arrives at destination z Receiver controls rate at which sender transmits to prevent buffer overflow

Application

Transport segments buffer used

buffer advertised buffer available = B

window size < B 62 Congestion Control

z Available bandwidth to destination varies with activity of other users z Transmitter dynamically adjusts transmission rate according to network congestion as indicated by RTT (round trip time) & ACKs z Elastic utilization of network bandwidth

Application

Transport segments

RTT buffer buffer Estimation ACKS

63 TCP Multiplexing z A TCP connection is specified by a 4-tuple z (source IP address, source port, destination IP address, destination port) z TCP allows multiplexing of multiple connections between end systems to support multiple applications simultaneously z Arriving segment directed according to connection 4-tuple

1 2 ... m 1 2 ... n 1 2 ... k

TCP TCP TCP

IP IP IP B C A (A, 6234, B, 80) 64 (A, 5234, B, 80) (C, 5234, B, 80) Outline z UDP Protocol z TCP Reliable Stream Service z TCP Protocol z TCP Connection Management z TCP Congestion Control

65 TCP Segment Format

0 4 10 16 24 31

Source port Destination port

Sequence number

Acknowledgment number

Header U A P R S F Reserved R C S S Y I Window size length G K H T N N

Checksum Urgent pointer

Options Padding

Data

• Each TCP segment has header of 20 or more bytes + 0 or more bytes of data66 TCP Header

Port Numbers Sequence Number z A socket identifies a z Byte count connection endpoint z First byte in segment z IP address + port z 32 bits long z A connection specified z 0 ≤ SN ≤ 232-1 by a socket pair z Initial sequence number z Well-known ports selected during z FTP 20 connection setup z Telnet 23 z DNS 53 z HTTP 80

67 TCP Header

Acknowledgement Header length Number z 4 bits z SN of next byte z Length of header in expected by receiver multiples of 32-bit z Acknowledges that all words prior bytes in stream z Minimum header length have been received is 20 bytes correctly z Maximum header z Valid if ACK flag is set length is 60 bytes

68 TCP Header

Reserved Control z 6 bits z 6 bits z URG: urgent pointer flag z Urgent message end = SN + urgent pointer z ACK: ACK packet flag z PSH: override TCP buffering z RST: reset connection z Upon receipt of RST, connection is terminated and application layer notified z SYN: establish connection z FIN: close connection 69 TCP Header

Window Size TCP Checksum z 16 bits to advertise z Internet checksum window size method z Used for flow control z TCP pseudoheader + z Sender will accept TCP segment bytes with SN from ACK to ACK + window z Maximum window size is 65535 bytes

70 TCP Checksum Calculation

0 8 16 31

Source IP address TCP pseudo- Destination IP address header

0 0 0 0 0 0 0 0 Protocol = 6 TCP segment length

z TCP error detection uses same procedure as UDP

71 TCP Header

Options Options z Variable length z Maximum Segment z NOP (No Operation) Size (MSS) option option is used to pad specifices largest TCP header to multiple segment a receiver of 32 bits wants to receive z Time stamp option is z Window Scale option used for round trip increases TCP window measurements from 16 to 32 bits

72 Outline z UDP Protocol z TCP Reliable Stream Service z TCP Protocol z TCP Connection Management z TCP Congestion Control

73 Initial Sequence Number z Select initial sequence numbers (ISN) to protect against segments from prior connections (that may circulate in the network and arrive at a much later time) z Select ISN to avoid overlap with sequence numbers of prior connections z Use local clock to select ISN sequence number z Time for clock to go through a full cycle should be greater than the maximum lifetime of a segment (MSL); Typically MSL=120 seconds z High bandwidth connections pose a problem z 2n > 2 * max packet life * R bytes/second

74 TCP Connection Establishment • “Three-way Handshake” • ISN’s protect against segments Host A from prior connections Host B

75 If host always uses the same ISN

Host A Host B

Delayed segment with Seq_no = n+2 will be accepted

76 Maximum Segment Size z Maximum Segment Size z largest block of data that TCP sends to other end z Each end can announce its MSS during connection establishment z Default is 576 bytes including 20 bytes for IP header and 20 bytes for TCP header z Ethernet implies MSS of 1460 bytes z IEEE 802.3 implies 1452

77 Client-Server Application Host A (client) Host B (server) socket bind socket t1 listen connect (blocks) (blocks) t2 accept

connect returnst3

write accept returns read (blocks) t4 t5 read (blocks)

read returns t6 write read (blocks) read returns 78 TCP Window Flow Control Host A Host B

t0

1024 bytes to transmit t 1024 bytes 1 to transmit

t2

1024 bytes 128 bytes to transmit to transmit

t3

1024 bytes to transmit t 4 can only send 512 bytes

79 Nagle Algorithm z Situation: user types 1 character at a time z Transmitter sends TCP segment per character (41B) z Receiver sends ACK (40B) z Receiver echoes received character (41B) z Transmitter ACKs echo (40 B) z 162 bytes transmitted to transfer 1 character! z Solution: z TCP sends data & waits for ACK z New characters buffered z Send new characters when ACK arrives z Algorithm adjusts to RTT z Short RTT send frequently at low efficiency z Long RTT send less frequently at greater efficiency 80 Silly Window Syndrome z Situation: z Transmitter sends large amount of data z Receiver buffer depleted slowly, so buffer fills z Every time a few bytes read from buffer, a new advertisement to transmitter is generated z Sender immediately sends data & fills buffer z Many small, inefficient segments are transmitted z Solution: z Receiver does not advertize window until window is at least ½ of receiver buffer or maximum segment size z Transmitter refrains from sending small segments

81 TCP Connection Closing “Graceful Close”

Host A Host B

Deliver 150 bytes

82 TCP State Transition CLOSED Appli- passive open, Diagram cation create TCB close LISTEN

application close receive SYN, or timeout, SYN_RCVD SYN_SENT send ACK delete TCB

application close, ESTABLISHED send FIN CLOSE_WAIT

FIN_WAIT_1 CLOSING

LAST_ACK

2MSL timeout FIN_WAIT_2 TIME_WAIT 83 delete TCB Outline z UDP Protocol z TCP Reliable Stream Service z TCP Protocol z TCP Connection Management z TCP Congestion Control

84 Phases of Congestion Behavior

R 1. Light traffic z Arrival Rate << R z Low delay z Can accommodate more

Throughput (bps) 2. Knee (congestion onset) Arrival z Arrival rate approaches R Rate z Delay increases rapidly z Throughput begins to saturate 3. Congestion collapse

Delay (sec) z Arrival rate > R z Large delays, packet loss Arrival z Useful application R Rate throughput drops 85 Window Congestion Control z Desired operating point: just before knee z Sources must control their sending rates so that aggregate arrival rate is just before knee z TCP sender maintains a congestion window cwnd to control congestion at intermediate routers z Effective window is minimum of congestion window and advertised window z Problem: source does not know what its “fair” share of available bandwidth should be z Solution: adapt dynamically to available BW z Sources probe the network by increasing cwnd z When congestion detected, sources reduce rate

z Ideally, sources sending rate stabilizes near ideal point 86 Congestion Window z How does the TCP congestion algorithm change congestion window dynamically according to the most up-to-date state of the network? z At light traffic: each segment is ACKed quickly z Increase cwnd aggresively z At knee: segment ACKs arrive, but more slowly z Slow down increase in cwnd z At congestion: segments encounter large delays (so retransmission timeouts occur); segments are dropped in router buffers (resulting in duplicate ACKs)

z Reduce transmission rate, then probe again 87 TCP Congestion Control: Slow Start

z Slow start: increase congestion window size by one segment upon receiving an ACK from receiver z initialized at ≤ 2 segments z used at (re)start of data transfer z congestion window increases exponentially

cwnd

Seg 8

4 2 1 ACK RTTs88 TCP Congestion Control: Congestion Avoidance z Algorithm progressively sets a congestion cwnd threshold z When cwnd > threshold, slow down rate at which 8 cwnd is increased threshold z Increase congestion window size by one segment per round-trip- time (RTT) 4 z Each time an ACK arrives, cwnd is increased by 2 1/cwnd 1 z In one RTT, cwnd segments are sent, so total increase in RTTs cwnd is cwnd x 1/cwnd = 1 z cwnd grows linearly with time 89 TCP Congestion Control: Congestion

z Congestion is detected Congestion upon timeout or receipt of avoidance 20 duplicate ACKs Time-out z Assume current cwnd corresponds to available 15 bandwidth z Adjust congestion threshold Threshold = ½ x current cwnd 10 z Reset cwnd to 1 z Go back to slow-start Congestion window Congestion Slow start z Over several cycles expect 5 to converge to congestion threshold equal to about ½ the available bandwidth 0

Round-trip times 90 Fast Retransmit & Fast Recovery z Congestion causes many segments to be dropped z If only a single segment is dropped, then subsequent segments trigger duplicate ACKs before timeout SN=1 ACK=2 z Can avoid large decrease in cwnd as SN=2 follows: SN=3 SN=4 ACK=2 z When three duplicate ACKs arrive, SN=5 ACK=2 retransmit lost segment immediately ACK=2 z Reset congestion threshold to ½ cwnd z Reset cwnd to congestion threshold + 3 to account for the three segments that triggered duplicate ACKs z Remain in congestion avoidance phase z However if timeout expires, reset cwnd to 1 z In absence of timeouts, cwnd will oscillate around optimal value 91 TCP Congestion Control: Fast Retransmit & Fast Recovery

Congestion avoidance 20 Time-out

15

Threshold 10

Congestion window Congestion Slow start 5

0

Round-trip times 92 Chapter 8 Communication Networks and Services

Internet Routing Protocols

93 Outline z Basic Routing z Routing Information Protocol (RIP) z Open Shortest Path First (OSPF) z Border Gateway Protocol (BGP)

94 Routing and Forwarding z Routing z How to determine the routing table entries zcarried out by routing daemon z Forwarding z Look up routing table & forward packet from input to output port zcarried out by IP layer

Routers exchange information using routing protocols to develop the routing tables 95 Autonomous Systems z Global Internet viewed as collection of autonomous systems. z Autonomous system (AS) is a set of routers or networks administered by a single organization z Same routing protocol need not be run within the AS z But, to the outside world, an AS should present a consistent picture of what ASs are reachable through it z Stub AS: has only a single connection to the outside world. z Multihomed AS: has multiple connections to the outside world, but refuses to carry transit traffic z Transit AS: has multiple connections to the outside world, and can carry transit and local traffic. 96 AS Number z For exterior routing, an AS needs a globally unique AS 16-bit integer number z Currently, there are about 11,000 registered ASs in Internet (and growing) z Stub AS, which is the most common type, does not need an AS number since the prefixes are placed at the provider’s routing table z Transit AS needs an AS number z Request an AS number from the ARIN, RIPE and APNIC

97 Inter and Intra Domain Routing

Interior Gateway Protocol (IGP): routing within AS • RIP, OSPF Exterior Gateway Protocol (EGP): routing between AS’s • BGPv4 Border Gateways perform IGP & EGP routing

IGP R EGP IGP R R R R R AS A AS C

R R IGP AS B 98 Outline z Basic Routing z Routing Information Protocol (RIP) z Open Shortest Path First (OSPF) z Border Gateway Protocol (BGP)

99 Routing Information Protocol (RIP) z RFC 1058 z RIP based on routed, “route d”, distributed in BSD UNIX z Uses the distance-vector algorithm z Runs on top of UDP, port number 520 z Metric: number of hops z Max limited to 15 z suitable for small networks (local area environments) z value of 16 is reserved to represent infinity z small number limits the count-to-infinity problem

100 RIP Operation z Router sends update message to neighbors every 30 sec z A router expects to receive an update message from each of its neighbors within 180 seconds in the worst case z If router does not receive update message from neighbor X within this limit, it assumes the link to X has failed and sets the corresponding minimum cost to 16 (infinity) z Uses split horizon with poisoned reverse z Convergence speeded up by triggered updates z neighbors notified immediately of changes in distance vector table

101 Outline z Basic Routing z Routing Information Protocol (RIP) z Open Shortest Path First (OSPF) z Border Gateway Protocol (BGP)

102 Open Shortest Path First z RFC 2328 (v2) z Fixes some of the deficiencies in RIP z Enables each router to learn complete network topology z Each router monitors the link state to each neighbor and floods the link-state information to other routers z Each router builds an identical link-state database z Allows router to build shortest path tree with router as root z OSPF typically converges faster than RIP when there is a failure in the network 103 OSPF Areas

To another AS

N1 R1 N5

N2 R3 R6 N4 R7

R2 N6 R4 R5

N3

Area 0.0.0.2 Area 0.0.0.1 R8 Area 0.0.0.0 ASB: 4 ABR: 3, 6, and 8 N7 IR: 1,2,7 R = router BBR: 3,4,5,6,8 Area 0.0.0.3 N = network 104 Outline z Basic Routing z Routing Information Protocol (RIP) z Open Shortest Path First (OSPF) z Border Gateway Protocol (BGP)

105 Exterior Gateway Protocols z Within each AS, there is a consistent set of routes connecting the constituent networks z The Internet is woven into a coherent whole by Exterior Gateway Protocols (EGPs) that operate between AS’s z EGP enables two AS’s to exchange routing information about: z The networks that are contained within each AS z The AS’s that can be reached through each AS z EGP path selection guided by policy rather than path optimality z Trust, peering arrangements, etc

106 EGP Example

Only EGP routers are shown R2 R3 N1 reachable AS2 through AS3

R1 R4 N1 AS1 AS3

• R4 advertises that network N1 can be reached through AS3 • R3 examines announcement & applies policy to decide whether it will forward packets to N1 through R4

• If yes, routing table updated in R3 to indicate R4 as next hop to N1107 • IGP propagates N1 reachability information through AS2 EGP Example

R2 R3 N1 reachable through AS2 AS2

R1 R4 N1 AS1 AS3

• EGP routers within an AS, e.g. R3 and R2, are kept consistent • Suppose AS2 willing to handle transit packets from AS1 to N1 • R2 advertises to AS1 the reachability of N1 through AS2 • R1 applies its policy to decide whether to send to N1 via AS2 108 Peering and Inter-AS connectivity

Peering Centre

Tier 1 ISP (Transit AS) Tier 1 ISP (Transit AS)

AS Tier 2 (transit AS) Tier 2 (transit AS) Content or Application Service Provider Tier 2 (transit AS) AS AS (Non-transit) AS AS AS AS

• Non-transit AS’s (stub & multihomed) do not carry transit traffic • Tier 1 ISPs peer with each other, privately & peering centers • Tier 2 ISPs peer with each other & obtain transit services from Tier

1s; Tier 1’s carry transit traffic between their Tier 2 customers 109 • Client AS’s obtain service from Tier 2 ISPs EGP Requirements z Scalability to global Internet z Provide connectivity at global scale z Link-state does not scale z Should promote address aggregation z Fully distributed z EGP path selection guided by policy rather than path optimality z Trust, peering arrangements, etc z EGP should allow flexibility in choice of paths

110 Border Gateway Protocol v4

AS2 AS1 AS6

AS3 AS5

AS4 AS7 z BGP (RFC 1771) an EGP routing protocol to exchange network reachability information among BGP routers (also called BGP speakers) z Network reachability info contains sequence of ASs that packets traverse to reach a destination network z Info exchanged between BGP speakers allows a router to construct a graph of AS connectivity z Routing loops can be pruned z Routing policy at AS level can be applied 111 BGP Features z BGP is path vector protocol: advertises sequence of AS numbers to the destination network z Path vector info used to prevent routing loops z BGP enforces policy through selection of different paths to a destination and by control of redistribution of routing information z Uses CIDR to support aggregation & reduction of routing information

112 BGP Speaker & AS Relationship z BGP speaker: a router running BGP z Peers or neighbors: two speakers exchanging information on a connection z BGP peers use TCP (port 179) to exchange messages z Initially, BGP peers exchange entire BGP routing table z Incremental updates sent subsequently z Reduces bandwidth usage and processing overhead z Keepalive messages sent periodically (30 seconds) z Internal BGP (iBPG) between BGP routers in same AS z External BGP (eBGP) connections across AS borders

113 iBGP & eBGP

R eBGP iBGP eBGP R R R iBGP iBGP iBGP iBGP

R R iBGP R R eBGP eBGP

z eBGP to exchange reachability information in different AS’s z eBGP peers directly connected z iBGP to ensure net reachability info is consistent among the BGP speakers in the same AS z usually not directly connected z iBGP speakers exchange info learned from other iBGP speakers, 114 and thus fully meshed Path Selection z Each BGP speaker z Evaluates paths to a destination from an AS border router z Selects the best that complies with policies z Advertises that route to all BGP neighbors z BGP assigns a preference order to each path & selects path with highest value; BGP does not keep a cost metric to any path z When multiple paths to a destination exist, BGP maintains all of the paths, but only advertises the one with highest preference value

115 BGP Policy z Examples of policy: z Never use AS X z Never use AS X to get to a destination in AS Y z Never use AS X and AS Y in the same path z Import policies to accept, deny, or set preferences on route advertisements from neighbors z Export policies to determine which routes should be advertised to which neighbors z A route is advertised only if AS is willing to carry traffic on that route 116 BGP Protocol z Opening & confirming of a BGP connection with a neighbor router z Maintaining the BGP connection z Sending reachability information z Notification of error conditions

117 Attributes

Attribute Type Attribute Length Attribute Value O T P E 0 Attribute Type Code

Attribute Codes LOCAL_PREF: informs other ORIGIN: defines origin of NLRI BGP speakers within the AS_PATH lists sequence of same AS of its degree of ASs that route has traversed preference for an advertised to reach the destination route NEXT_HOP defines IP address ATOMIC_AGGREGATE: of border router that should informs other BGP speakers be used as the next hop to that it selected a less the destinations listed in the specific route without NLRI. selecting a more specific one which is included in it. MULTI_EXIT_DISC: used to discriminate among multiple AGGREGATOR: specifies last entry/exit points to AS number that formed the neighboring AS and to hint aggregate route followed by about the preferred path. the IP address of the BGP speaker that formed the 118 aggregate route