1.36k likes | 1.67k Views
Chapter 4: Network Layer. Chapter goals: understand principles behind network layer services: network layer service models forwarding versus routing how a router works routing (path selection) broadcast, multicast instantiation, implementation in the Internet. 4. 1 Introduction
E N D
Chapter 4:Network Layer Chapter goals: • understand principles behind network layer services: • network layer service models • forwarding versus routing • how a router works • routing (path selection) • broadcast, multicast • instantiation, implementation in the Internet Network Layer
4. 1 Introduction 4.2 Virtual circuit and datagram networks 4.3 What’s inside a router 4.4 IP: Internet Protocol Datagram format IPv4 addressing ICMP IPv6 4.5 Routing algorithms Link state Distance Vector Hierarchical routing 4.6 Routing in the Internet RIP OSPF BGP 4.7 Broadcast and multicast routing Chapter 4: Network Layer Network Layer
transport segment from sending to receiving host on sending side encapsulates segments into datagrams on rcving side, delivers segments to transport layer network layer protocols in every host, router router examines header fields in all IP datagrams passing through it network data link physical network data link physical network data link physical network data link physical network data link physical network data link physical network data link physical network data link physical network data link physical network data link physical network data link physical application transport network data link physical application transport network data link physical Network layer Network Layer
Two Key Network-Layer Functions • forwarding: move packets from router’s input to appropriate router output • routing: determine route taken by packets from source to dest. • The algorithms that calculate these paths are referred to as routing algorithms. analogy: • routing: process of planning trip from source to dest • forwarding: process of getting through single interchange Network Layer
Every router has a forwarding table. • A router forwards a packet by examining the value of a field in the arriving packet's header, and then using this value to index into the router's forwarding table. • The result from the forwarding table indicates to which of the router's outgoing link interfaces the packet is to be forwarded. • Depending on the network-layer protocol, this value in the packet's header could be the destination address of the packet or an indication of the connection to which the packet belongs. Network Layer
routing algorithm local forwarding table header value output link 0100 0101 0111 1001 3 2 2 1 value in arriving packet’s header 1 0111 2 3 Interplay between routing and forwarding Network Layer
Connection setup • Network-layer architectures—for example, ATM and frame-relay, but not the Internet-establish virtual connection before datagrams flow between two end hosts and intervening routers • network vs transport layer connection service: • network: between two hosts (may also involve intervening routers in case of VCs) • transport: between two processes Network Layer
example services for individual datagrams: This service guarantees that the packet will eventually arrive at its destination. guaranteed delivery with less than 40 msec delay example services for a flow of datagrams: in-order datagram delivery guaranteed minimum bandwidth to flow restrictions on changes in inter-packet spacing Network service model:The network service model defines the characteristics of end-to-end transport of packets Q: What service model for “channel” transporting datagrams from sender to receiver? Network Layer
Network service model:The network service model defines the characteristics of end-to-end transport of packets Q: What service model for “channel” transporting datagrams from sender to receiver? Example services for individual datagrams: • Guaranteed delivery. This service guarantees that the packet will eventually arrive at its destination. • Guaranteed delivery with bounded delay. This service not only guarantees delivery of the packet, but delivery within a specified host-to-host delay bound (for example, within 100 msec). Network Layer
Example services for a flow of datagrams: • In-order packet delivery. This service guarantees that packets arrive at the destination in the order that they were sent. • Guaranteed minimal bandwidth. This network-layer service emulates the behavior of a transmission link of a specified bit rate (for example, 1 Mbps) between sending and receiving hosts • even though the actual end-to-end path may traverse several physical links Network Layer
Guaranteed maximum jitter. This service guarantees that the amount of time between the transmission of two successive packets at the sender is equal to the amount of time between their receipt at the destination • that this spacing changes by no more than some specified value • Security services. Using a secret session key known only by a source and destination host, the network layer in the source host could encrypt the payloads of all datagrams being sent to the destination host. • The network layer in the destination host would then be responsible for decrypting the payloads. • With such a service, confidentiality would be provided to all transport-layer segments (TCP and UDP) between the source and destination hosts. • Also, the network layer could provide data integrity and source authentication services. Network Layer
Constant bit rate (CBR) • An ATM network service for carrying real-time, constant bit rate audio and video traffic. • The goal of CBR service is to provide a flow of packets (known as cells) with a virtual pipe whose properties are the same as if a dedicated fixed-bandwidth transmission link existed between sending and receiving hosts. • With CBR service, a flow of ATM cells is carried across the network in such a way that a cell's end-to-end delay, the variability in a cell's end-end delay (that is, the jitter), and the fraction of cells that are lost or delivered late are all guaranteed to be less than specified values. Network Layer
Available bit rate (ABR) ATM network service. • Cells may be lost under ABR service. • Cells cannot be reordered • Minimum cell transmission rate (MCR) is guaranteed to a connection using ABR service. • If the network has enough free resources at a given time, a sender may also be able to send cells successfully at a higher rate than the MCR. • ATM ABR service can provide feedback to the sender (in terms of a congestion notification bit, or an explicit rate at which to send) that controls how the sender adjusts its rate between the MCR and an allowable peak cell rate. Network Layer
Network layer service models: Guarantees ? Network Architecture Internet ATM ATM ATM ATM Service Model best effort CBR VBR ABR UBR Congestion feedback no (inferred via loss) no congestion no congestion yes no Bandwidth none constant rate guaranteed rate guaranteed minimum none Loss no yes yes no no Order no yes yes yes yes Timing no yes yes no no Network Layer
4. 1 Introduction 4.2 Virtual circuit and datagram networks 4.3 What’s inside a router 4.4 IP: Internet Protocol Datagram format IPv4 addressing ICMP IPv6 4.5 Routing algorithms Link state Distance Vector Hierarchical routing 4.6 Routing in the Internet RIP OSPF BGP 4.7 Broadcast and multicast routing Chapter 4: Network Layer Network Layer
Network layer connection and connection-less service • datagram network provides network-layer connectionless service • VC network provides network-layer connection service • analogous to the transport-layer services, but: • service: host-to-host • no choice: network provides one or the other • implementation: in network core Network Layer
call setup, teardown for each call before data can flow each packet carries VC identifier (not destination host address) every router on source-dest path maintains “state” for each passing connection link, router resources (bandwidth, buffers) may be allocated to VC (dedicated resources = predictable service) “source-to-dest path behaves much like telephone circuit” performance-wise network actions along source-to-dest path Virtual circuits Network Layer
VC implementation a VC consists of: • path from source to destination • VC numbers, one number for each link along path • entries in forwarding tables in routers along path • packet belonging to VC carries VC number (rather than dest address) • VC number can be changed on each link. • New VC number comes from forwarding table Network Layer
VC number 22 32 12 3 1 2 interface number Incoming interface Incoming VC # Outgoing interface Outgoing VC # 1 12 3 22 2 63 1 18 3 7 2 17 1 97 3 87 … … … … VC Forwarding table Forwarding table in northwest router: Routers maintain connection state information! Network Layer
used to setup, maintain teardown VC used in ATM, frame-relay, X.25 not used in today’s Internet application transport network data link physical application transport network data link physical Virtual circuits: signaling protocols 6. Receive data 5. Data flow begins 4. Call connected 3. Accept call 1. Initiate call 2. incoming call Network Layer
Phases in a virtual circuit: • VC setup: During the setup phase, the sending transport layer contacts the network layer, specifies the receiver's address, and waits for the network to set up the VC. • The network layer determines the path between sender and receiver, that is, the series of links and routers through which all packets of the VC will travel. • The network layer also determines the VC number for each link along the path. • Finally, the network layer adds an entry in the forwarding table in each router along the path. • During VC setup, the network layer may also reserve resources (for example, bandwidth) along the path of the VC. Network Layer
Data transfer: Once the VC has been established, packets can begin to flow along the VC. • VC teardown: This is initiated when the sender (or receiver) informs the network layer of its desire to terminate the VC. • The network layer will then typically inform the end system on the other side of the network of the call termination and • update the forwarding tables in each of the packet routers on the path to indicate that the VC no longer exists. Network Layer
With a VC network layer, routers along the path between the two end systems are involved in VC setup, and • each router is fully aware of all the VCs passing through it. • The messages that the end systems send into the network to initiate or terminate a VC, and the messages passed between the routers to set up the VC (that is, to modify connection state in router tables) are known as signaling messages • The protocols used to exchange these messages are often referred to as signaling protocols. Network Layer
no call setup at network layer routers: no state about end-to-end connections no network-level concept of “connection” packets forwarded using destination host address packets between same source-destination pair may take different paths application transport network data link physical application transport network data link physical Datagram networks 2. Receive data 1. Send data Network Layer
4 billion IP addresses, so rather than list individual destination address list range of addresses (aggregate table entries) Datagram Forwarding table routing algorithm local forwarding table dest address output link address-range 1 address-range 2 address-range 3 address-range 4 3 2 2 1 IP destination address in arriving packet’s header 1 2 3 Network Layer
Datagram Forwarding table Destination Address Range 11001000 00010111 00010000 00000000 through 11001000 00010111 00010111 11111111 11001000 00010111 00011000 00000000 through 11001000 00010111 00011000 11111111 11001000 00010111 00011001 00000000 through 11001000 00010111 00011111 11111111 otherwise Link Interface 0 1 2 3 Q: but what happens if ranges don’t divide up so nicely? Network Layer
Longest prefix matching Longest prefix matching when looking for forwarding table entry for given destination address, use longest address prefix that matches destination address. Link interface 0 1 2 3 Destination Address Range 11001000 00010111 00010*** ********* 11001000 00010111 00011000 ********* 11001000 00010111 00011*** ********* otherwise Examples: DA: 11001000 00010111 00010110 10100001 Which interface? Which interface? DA: 11001000 00010111 00011000 10101010 Network Layer
Internet (datagram) data exchange among computers “elastic” service, no strict timing req. “smart” end systems (computers) can adapt, perform control, error recovery simple inside network, complexity at “edge” many link types different characteristics uniform service difficult ATM (VC) evolved from telephony human conversation: strict timing, reliability requirements need for guaranteed service “dumb” end systems telephones complexity inside network Datagram or VC network: why? Network Layer
4. 1 Introduction 4.2 Virtual circuit and datagram networks 4.3 What’s inside a router? 4.4 IP: Internet Protocol Datagram format IPv4 addressing ICMP IPv6 4.5 Routing algorithms Link state Distance Vector Hierarchical routing 4.6 Routing in the Internet RIP OSPF BGP 4.7 Broadcast and multicast routing Chapter 4: Network Layer Network Layer
switching fabric router input ports router output ports routing processor Router Architecture Overview two key router functions: • run routing algorithms/protocol (RIP, OSPF, BGP) • forwarding datagrams from incoming to outgoing link Network Layer
Input Port Functions lookup, forwarding queueing Decentralized switching: • given datagram dest., lookup output port using forwarding table in input port memory • goal: complete input port processing at ‘line speed’ • queuing: if datagrams arrive faster than forwarding rate into switch fabric link layer protocol (receive) switch fabric line termination Physical layer: terminating an incoming physical link to a router. bit-level reception Data link layer: e.g., Ethernet Network Layer
Switching fabrics • transfer packet from input buffer to appropriate output buffer • switching rate: rate at which packets can be transfer from inputs to outputs • often measured as multiple of input/output line rate • N inputs: switching rate N times line rate desirable • three types of switching fabrics memory bus memory crossbar Network Layer
output port (e.g., Ethernet) input port (e.g., Ethernet) memory system bus Switching Via Memory First generation routers: • traditional computers with switching under direct control of CPU • packet copied to system’s memory • speed limited by memory bandwidth (2 bus crossings per datagram) Network Layer
Switching Via a Bus • datagram from input port memory to output port memory via a shared bus • bus contention: Because every packet must cross the single bus, the switching bandwidth of the router is limited to the bus speed. • Cisco 5600, switches packets over a 32 Gbps backplane bus. bus Network Layer
crossbar Switching Via An Interconnection Network • Overcome bus bandwidth limitations • A crossbar switch is an interconnection network consisting of 2n buses that connect n input ports to n output ports, • If the vertical bus leading to the output port is free, the packet is transferred to the output port. • If the vertical bus is being used to transfer a packet from another input port to this same output port, the arriving packet is blocked and must be queued at the input port. • advanced design: fragmenting datagram into fixed length cells, switch cells through the fabric. • Banyan networks, crossbar, other interconnection nets was used in the past to interconnect processors in a multiprocessor computer architecture. • Cisco 12000: switches 60 Gbps through the interconnection network Network Layer
The input port processing to be able to proceed at line speed • for a lookup to be performed in less than the amount of time needed to receive a packet at the input port. • In this case, input processing of a received packet can be completed before the next receive operation is complete. • To get an idea of the performance requirements for a lookup, consider that an OC-48 link runs at 2.5 Gbps. • With packets 256 bytes long, this implies a lookup speed of approximately 1 million lookups per second. Network Layer
datagram buffer queueing Output Ports • buffering required when datagrams arrive from fabric faster than the transmission rate • scheduling discipline chooses among queued datagrams for transmission switch fabric line termination link layer protocol (send) Network Layer
switch fabric switch fabric one packet time later at t, packets more from input to output Output port queueing • buffering when arrival rate via switch exceeds output line speed • queueing (delay) and loss due to output port buffer overflow! Network Layer
Routing processor. • The routing processor executes the routing protocols, • maintains • the routing information and • forwarding tables, • performs network management functions within the router. Network Layer
. RTT C N How much buffering? • RFC 3439 rule of thumb: average buffering equal to = RTT.C • e.g., with C = 10 Gpbs and RTT= 250 ms • link: 2.5 Gbit buffer • recent recommendation: with N flows, buffering equal to Network Layer
Input Port Queuing • fabric slower than input ports combined -> queueing may occur at input queues • queueing delay and loss due to input buffer overflow! • Head-of-the-Line (HOL) blocking: queued datagram at front of queue prevents others in queue from moving forward switch fabric switch fabric one packet time later: green packet experiences HOL blocking output port contention: only one red datagram can be transferred.lower red packet is blocked Network Layer
4. 1 Introduction 4.2 Virtual circuit and datagram networks 4.3 What’s inside a router 4.4 IP: Internet Protocol Datagram format IPv4 addressing ICMP IPv6 4.5 Routing algorithms Link state Distance Vector Hierarchical routing 4.6 Routing in the Internet RIP OSPF BGP 4.7 Broadcast and multicast routing Chapter 4: Network Layer Network Layer
Host, router network layer functions: • ICMP protocol • error reporting • router “signaling” • IP protocol • addressing conventions • datagram format • packet handling conventions • Routing protocols • path selection • RIP, OSPF, BGP forwarding table The Internet Network layer Transport layer: TCP, UDP Network layer Link layer physical layer Network Layer
4. 1 Introduction 4.2 Virtual circuit and datagram networks 4.3 What’s inside a router 4.4 IP: Internet Protocol Datagram format IPv4 addressing ICMP IPv6 4.5 Routing algorithms Link state Distance Vector Hierarchical routing 4.6 Routing in the Internet RIP OSPF BGP 4.7 Broadcast and multicast routing Chapter 4: Network Layer Network Layer
IP protocol version number 32 bits total datagram length (bytes) header length (bytes) type of service head. len ver length for fragmentation/ reassembly fragment offset “type” of data flgs 16-bit identifier max number remaining hops (decremented at each router) upper layer time to live header checksum 32 bit source IP address 32 bit destination IP address upper layer protocol to deliver payload to E.g. timestamp, record route taken, specify list of routers to visit. Options (if any) data (variable length, typically a TCP or UDP segment) IP datagram format how much overhead with TCP? • 20 bytes of TCP • 20 bytes of IP • = 40 bytes + app layer overhead Network Layer
network links have MTU (max.transfer size) - largest possible link-level frame. different link types, different MTUs large IP datagram divided (“fragmented”) within net one datagram becomes several datagrams “reassembled” only at final destination IP header bits used to identify, order related fragments IP Fragmentation & Reassembly fragmentation: in: one large datagram out: 3 smaller datagrams reassembly Network Layer
length =1500 length =1040 length =1500 length =4000 ID =x ID =x ID =x ID =x fragflag =0 fragflag =0 fragflag =1 fragflag =1 offset =0 offset =185 offset =0 offset =370 One large datagram becomes several smaller datagrams IP Fragmentation and Reassembly Example • 4000 byte datagram • MTU = 1500 bytes 1480 bytes in data field offset = 1480/8 Network Layer
4. 1 Introduction 4.2 Virtual circuit and datagram networks 4.3 What’s inside a router 4.4 IP: Internet Protocol Datagram format IPv4 addressing ICMP IPv6 4.5 Routing algorithms Link state Distance Vector Hierarchical routing 4.6 Routing in the Internet RIP OSPF BGP 4.7 Broadcast and multicast routing Chapter 4: Network Layer Network Layer
IP address: 32-bit identifier for host, router interface interface: connection between host/router and physical link router’s typically have multiple interfaces host typically has one interface IP addresses associated with each interface 223.1.1.2 223.1.2.2 223.1.2.1 223.1.3.2 223.1.3.1 223.1.3.27 IP Addressing: introduction 223.1.1.1 223.1.2.9 223.1.1.4 223.1.1.3 223.1.1.1 = 11011111 00000001 00000001 00000001 223 1 1 1 Network Layer
Recipe to determine the subnets, detach each interface from its host or router, creating islands of isolated networks each isolated network is called a subnet. 223.1.1.0/24 223.1.2.0/24 223.1.3.0/24 Subnets Subnet mask: /24 Network Layer