Chapter 4: Network Layer, partb

Similar documents
Chapter 4 Network Layer

Internet rou)ng. V. Arun CS491G: Computer Networking Lab University of MassachuseFs Amherst

Last time. Transitioning to IPv6. Routing. Tunneling. Gateways. Graph abstraction. Link-state routing. Distance-vector routing. Dijkstra's Algorithm

Chapter 4: outline. Network Layer 4-1

CSC 4900 Computer Networks: Routing Algorithms

Chapter 4: Network Layer

Chapter IV: Network Layer

Lecture 9. Network Layer (cont d) Network Layer 1-1

Chapter 4: Network Layer. Lecture 12 Internet Routing Protocols. Chapter goals: understand principles behind network layer services:

Hierarchical Routing. Our routing study thus far - idealization all routers identical network flat not true in practice

Chapter 5 Network Layer: The Control Plane

DATA COMMUNICATOIN NETWORKING

Network layer: Overview. Network layer functions Routing IP Forwarding

DATA COMMUNICATOIN NETWORKING

CSC 8560 Computer Networks: Control Plane

Lecture 4. The Network Layer (cont d)

CMPE 80N: Introduction to Networking and the Internet. Katia Obraczka Computer Engineering UCSC Baskin Engineering Lecture 20

CSC 4900 Computer Networks: Routing Protocols

CSCE 463/612 Networks and Distributed Processing Spring 2018

Computer Networking Introduction

CS 43: Computer Networks Internet Routing. Kevin Webb Swarthmore College November 14, 2013

Inter-AS routing and BGP. Network Layer 4-1

5.1 introduction 5.5 The SDN control 5.2 routing protocols plane. Control Message 5.3 intra-as routing in Protocol the Internet

EC441 Fall 2018 Introduction to Computer Networking Chapter 5: Network Layer Control Plane

Internet Protocol: Routing Algorithms. Srinidhi Varadarajan

CSCI Topics: Internet Programming Fall 2008

ELEC / COMP 177 Fall Some slides from Kurose and Ross, Computer Networking, 5 th Edition

CS 43: Computer Networks Internet Routing. Kevin Webb Swarthmore College November 16, 2017

Network Routing. Packet Routing, Routing Algorithms, Routers, Router Architecture

Network layer: Overview. Network layer functions Routing IP Forwarding

Chapter 4: Network Layer

CS555, Spring /5/2005. April 12, 2005 No classes attend Senior Design Projects conference. Chapter 4 roadmap. Internet AS Hierarchy

Chapter 4: outline. 4.5 routing algorithms link state distance vector hierarchical routing. 4.6 routing in the Internet RIP OSPF BGP

CS 43: Computer Networks. 24: Internet Routing November 19, 2018

Announcements. CS 5565 Network Architecture and Protocols. Project 2B. Project 2B. Project 2B: Under the hood. Routing Algorithms

CSCD 330 Network Programming Spring 2018

CSCD 330 Network Programming Spring 2017

Course on Computer Communication and Networks. Lecture 7 Network Layer, Chapter 4 (6/e) - Part B (7/e Ch5)

Network layer. Network Layer 4-1. application transport network data link physical. network data link physical. network data link physical

Network Layer: Routing

CSc 450/550 Computer Networks Internet Routing

Data Communications & Networks. Session 7 Main Theme Networks: Part II Circuit Switching, Packet Switching, The Network Layer

Routing in the Internet

Initial motivation: 32-bit address space soon to be completely allocated. Additional motivation:

CSC 401 Data and Computer Communications Networks

Chapter 4 Network Layer. Network Layer 4-1

Inter-AS routing. Computer Networking: A Top Down Approach 6 th edition Jim Kurose, Keith Ross Addison-Wesley

Module 3 Network Layer CS755! 3-1!

Department of Computer Science Southern Illinois University Carbondale

Chapter 4: Network Layer: Part II

Master Course Computer Networks IN2097

CMPE 150/L : Introduction to Computer Networks. Chen Qian Computer Engineering UCSC Baskin Engineering Lecture 13

CMPE 150/L : Introduction to Computer Networks. Chen Qian Computer Engineering UCSC Baskin Engineering Lecture 14

Graph abstraction: costs. Graph abstraction 10/26/2018. Interplay between routing and forwarding

Chapter 4: Network Layer. TDTS06 Computer networks. Subnets. Subnets. Subnets. IP Addressing: introduction

Interplay Between Routing, Forwarding

Chapter 4: Network Layer. Chapter 4 Network Layer. Chapter 4: Network Layer. Network layer. Chapter goals:

Interplay between routing, forwarding

Computer Networks. Instructor: Niklas Carlsson

Dynamic Routing. The Protocols

Network Layer: Control Plane 5-2

Topics for This Week

Routing. Outline. Algorithms Scalability

Chapter 5 Network Layer: The Control Plane

Network Layer: Routing. Routing. Routing protocol. Graph abstraction for routing algorithms: graph nodes are routers graph edges are physical links

CS118 Discussion 1A, Week 7. Zengwen Yuan Dodd Hall 78, Friday 10:00 11:50 a.m.

CS 457 Networking and the Internet. Shortest-Path Problem. Dijkstra s Shortest-Path Algorithm 9/29/16. Fall 2016

Chapter 5 Network Layer: The Control Plane

Chapter 5 Network Layer: The Control Plane

Chapter 5 Network Layer: The Control Plane

Chapter 4: Network Layer

Chapter 4 Network Layer

ELEC / COMP 177 Fall Some slides from Kurose and Ross, Computer Networking, 5 th Edition

The Internet network layer

BGP. Daniel Zappala. CS 460 Computer Networking Brigham Young University

COMP211 Chapter 5 Network Layer: The Control Plane

Lecture 19: Network Layer Routing in the Internet

Telecomunicazioni. Docente: Andrea Baiocchi. DIET - Stanza 107, 1 piano palazzina P. Piga Via Eudossiana 18

CSCE 463/612 Networks and Distributed Processing Spring 2017

Chapter 4: Network Layer

Network Layer. CMPS 4750/6750: Computer Networks

Intra-AS Routing. Computer Networking: A Top Down Approach 6 th edition Jim Kurose, Keith Ross Addison-Wesley.

Routing. Jens A Andersson Communication Systems

Master Course Computer Networks IN2097

Routing Unicast routing protocols

COMP 3331/9331: Computer Networks and Applications

Chapter 4: Network Layer. Chapter 4: Network Layer

Chapter 4 Network Layer

Shortest Paths Algorithms and the Internet: The Distributed Bellman Ford Lecturer: Prof. Chiara Petrioli

Routing Algorithm Classification. A Link-State Routing Algorithm

CS 204: BGP. Jiasi Chen Lectures: MWF 12:10-1pm Humanities and Social Sciences

Chapter 4 Network Layer

Telecomunicazioni. Docente: Andrea Baiocchi DIET - Stanza 107, 1 piano palazzina P. Piga Via Eudossiana 18

Chapter 4 Network Layer

UNIT III THE NETWORK LAYER

EE 122: Intra-domain routing

Chapter 4 Network Layer

Chapter 4 Network Layer. Chapter 4: Network Layer. Chapter 4: Network Layer. Chapter goals: understand principles behind network layer services:

Initial motivation: 32-bit address space soon to be completely allocated. Additional motivation:

Network layer functions. Chapter 4 Network Layer. Network layer functions. Network layer functions

Transcription:

Chapter 4: Network Layer, partb The slides are adaptations of the slides available by the main textbook authors, Kurose&Ross Network Layer 4-1

Interplay between routing, forwarding routing algorithm local forwarding table header value output link 0100 0101 0111 1001 3 2 2 1 value in arriving packet s header 0111 3 2 1 Network Layer 4-2

Chapter 4: 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 Network Layer 4-3

Graph abstraction 5 u 1 2 v 2 x 3 1 3 w y 1 5 2 z Graph: G = (N,E) N = set of routers = { u, v, w, x, y, z } E = set of links ={ (u,v), (u,x), (v,x), (v,w), (x,w), (x,y), (w,y), (w,z), (y,z) } c(x,x ) = cost of link (x,x ) - e.g., c(w,z) = 5 cost could always be 1, or inversely related to bandwidth, or inversely related to congestion or something else Cost of path (x 1, x 2, x 3,, x p ) = c(x 1,x 2 ) + c(x 2,x 3 ) + + c(x p-1,x p ) Question: What s the least-cost path between u and z? Routing algorithm: algorithm that finds least-cost path Network Layer 4-4

Routing Algorithm classification Global or decentralized information? Global: all routers have complete topology, link cost info link state algorithms Decentralized: router knows physicallyconnected neighbors, link costs to neighbors iterative process of computation, exchange of info with neighbors distance vector algorithms Static or dynamic? Static: routes don t change (or do soslowly over time) Dynamic: routes change periodic update in response to link cost changes Network Layer 4-5

Chapter 4: 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 Network Layer 4-6

A Link-State Routing Algorithm Dijkstra s algorithm net topology, link costs known to all nodes accomplished via link state broadcast all nodes have same info computes least cost paths from one node ( source ) to all other nodes gives forwarding table for that node iterative: after k iterations, know least cost path to k dest. s Notation: c(x,y): link cost from node x to y; = if not direct neighbors D(v): current value of cost of path from source to dest. v p(v): predecessor node along path from source to v N': set of nodes whose least cost path definitively known Network Layer 4-7

Dijkstra s Algorithm 1 Initialization: 2 N' = {u} 3 for all nodes v 4 if v adjacent to u 5 then D(v) = c(u,v) 6 else D(v) = 7 8 Loop 9 find w not in N' such that D(w) is a minimum 10 add w to N' 11 update D(v) for all v adjacent to w and not in N' : 12 D(v) = min( D(v), D(w) + c(w,v) ) 13 /* new cost to v is either old cost to v or known 14 shortest path cost to w plus cost from w to v */ 15 until all nodes in N' Network Layer 4-8

Network Layer 4-9 Dijkstra s algorithm: example Step 0 1 2 3 4 5 N' u ux uxy uxyv uxyvw uxyvwz D(v),p(v) 2,u 2,u 2,u D(w),p(w) 5,u 4,x 3,y 3,y D(x),p(x) 1,u D(y),p(y) 2,x D(z),p(z) 4,y 4,y 4,y u y x w v z 2 2 1 3 1 1 2 5 3 5

Dijkstra s algorithm: example (2) Resulting shortest-path tree from u: v w u z x y Resulting forwarding table in u: destination v x y w z link (u,v) (u,x) (u,x) (u,x) (u,x) Network Layer 4-10

Dijkstra s algorithm, discussion Algorithm complexity: n nodes each iteration: need to check all nodes, w, not in N n(n+1)/2 comparisons: O(n 2 ) more efficient implementations possible: O(nlogn) Oscillations possible: e.g., link cost = amount of carried traffic 1 A 1 1+e D B 0 0 0 C e 1 e initially A 2+e 0 D B 0 1+e 1 C 0 recompute routing A 0 2+e D B 0 0 1 C 1+e recompute A 2+e 0 D B 0 1+e 1 C e recompute Network Layer 4-11

Chapter 4: 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 Network Layer 4-12

Distance Vector Algorithm Bellman-Ford Equation Define d x (y) := cost of least-cost path from x to y Then d x (y) = min {c(x,v) + d v (y) } v where min is taken over all neighbors v of x Network Layer 4-13

Bellman-Ford example u 1 2 5 v 2 x 3 1 3 w y 1 5 2 z Clearly, d v (z) = 5, d x (z) = 3, d w (z) = 3 B-F equation says: d u (z) = min { c(u,v) + d v (z), c(u,x) + d x (z), c(u,w) + d w (z) } = min {2 + 5, 1 + 3, 5 + 3} = 4 Node that achieves minimum is next hop in shortest path forwarding table Network Layer 4-14

Distance Vector Algorithm D x (y) = estimate of least cost from x to y Node x knows cost to each neighbor v: c(x,v) Node x maintains distance vector D x = [D x (y): y є N ] Node x also needs to know its neighbors distance vectors For each neighbor v, x knows D v = [D v (y): y є N ] Network Layer 4-15

Distance vector algorithm (4) Basic idea: From time-to-time, each node sends its own distance vector estimate to neighbors Asynchronous When a node x receives new DV estimate from neighbor, it updates its own DV using B-F equation: D x (y) min v {c(x,v) + D v (y)} for each node y N Under minor, natural conditions, the estimate D x (y) converges to the actual least cost d x (y) Network Layer 4-16

Distance Vector Algorithm (5) Iterative, asynchronous: each local iteration caused by: local link cost change DV update message from neighbor Distributed: each node notifies neighbors only when its DV changes neighbors then notify their neighbors if necessary Each node: wait for (change in local link cost or msg from neighbor) recompute estimates if DV to any dest has changed, notify neighbors Network Layer 4-17

D x (y) = min{c(x,y) + D y (y), c(x,z) + D z (y)} = min{2+0, 7+1} = 2 node x table cost to cost to x y z x y z x 0 2 7 y z node y table cost to x y z from x y 2 0 1 z node z table cost to x y z from from x y z 71 0 from x y z 0 2 3 2 0 1 7 1 0 time D x (z) = min{c(x,y) + D y (z), c(x,z) + D z (z)} = min{2+1, 7+0} = 3 x 2 y 7 1 z Network Layer 4-18

D x (y) = min{c(x,y) + D y (y), c(x,z) + D z (y)} = min{2+0, 7+1} = 2 node x table cost to cost to cost to x y z x y z x y z x 0 2 7 x 0 2 3 x 0 2 3 y y 2 0 1 y 2 0 1 z z 7 1 0 z 3 1 0 node y table cost to cost to cost to x y z x y z x y z x x 0 2 7 x 0 2 3 y 2 0 1 y 2 0 1 y 2 0 1 z z 7 1 0 z 3 1 0 node z table cost to cost to cost to x y z x y z x y z from from from x y z 71 0 from from from x y z 0 2 7 2 0 1 3 1 0 from from from x y z 0 2 3 2 0 1 3 1 0 time D x (z) = min{c(x,y) + D y (z), c(x,z) + D z (z)} = min{2+1, 7+0} = 3 x 2 y 7 1 z Network Layer 4-19

Distance Vector: link cost changes Link cost changes: node detects local link cost change updates routing info, recalculates distance vector if DV changes, notify neighbors x 1 4 y 50 1 z good news travels fast At time t 0, y detects the link-cost change, updates its DV, and informs its neighbors. At time t 1, z receives the update from y and updates its table. It computes a new least cost to x and sends its neighbors its DV. At time t 2, y receives z s update and updates its distance table. y s least costs do not change and hence y does not send any message to z. Network Layer 4-20

Distance Vector: link cost changes Link cost changes: node detects local link cost change updates distance table if cost change in least cost path, notify neighbors 1 X 4 Y 50 1 Z good news travels fast y to x y to x, via y to x, via y to x via z to x z to x, via z to x, via z to x, via algorithm terminates 4: Network Layer 4a-21

Distance Vector: link cost changes Link cost changes: good news travels fast 60 bad news travels slow (watch: Y loops!) - count to infinity 4 1 problem! X Z 50 Y to x, via Y to x, via Y to x, via Y to x, via Y to x, via z to x, via z to x, via z to x, via z to x, via z to x, via algorithm continues on! 4: Network Layer 4a-22

Distance Vector:count to infinity problem: way out? Poisoned reverse: If Z routes through Y to get to X : Z tells Y its (Z s) distance to X is infinite (so Y won t route to X via Z) 60 x 4 y 50 1 z Network Layer 4-23

Comparison of LS and DV algorithms Message complexity LS: with n nodes, E links, O(nE) msgs sent DV: exchange between neighbors only Speed of Convergence LS: O(n 2 ) algorithm may have oscillations DV: convergence time varies may be routing loops count-to-infinity problem Robustness: what happens if router malfunctions? LS: DV: node can advertise incorrect link cost each node computes only its own table DV node can advertise incorrect path cost each node s table used by others error propagates thru network Network Layer 4-24

Chapter 4: 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 Network Layer 4-25

Hierarchical Routing Recall: all routers identical network flat not true in practice scale: with 200 million destinations: can t store all dest s in routing tables! routing table exchange would swamp links! administrative autonomy internet = network of networks each network admin may want to control routing in its own network Network Layer 4-26

3c 3a 3b AS3 1c 1a 1d aggregate routers into regions, autonomous systems (AS) routers in same AS run same routing protocol Hierarchical Routing: Interconnected ASes intra-as routing protocol routers in different AS can run different intra-as routing protocol 1b Intra-AS Routing algorithm AS1 Forwarding table Inter-AS Routing algorithm 2a 2c 2b AS2 Gateway router Direct link to router in another AS forwarding table configured by both intra- and inter-as routing algorithm intra-as sets entries for internal dests inter-as & intra-as sets entries for external dests Network Layer 4-27

Inter-AS tasks suppose router in AS1 receives datagram destined outside of AS1: router should forward packet to gateway router, but which one? AS1 must: 1. learn which dests are reachable through AS2, which through AS3 2. propagate this reachability info to all routers in AS1 Job of inter-as routing! 3c 3a 3b AS3 1a 1c 1d 1b AS1 2a 2c 2b AS2 Network Layer 4-28

Example 1: Setting forwarding table in router 1d suppose AS1 learns (via inter-as protocol) that subnet x reachable via AS3 (gateway 1c) but not via AS2. inter-as protocol propagates reachability info to all internal routers. router 1d determines from intra-as routing info that its interface I is on the least cost path to 1c. installs forwarding table entry (x,i) x 3c 3a 3b AS3 1a 1c 1d 1b AS1 2a 2c 2b AS2 Network Layer 4-29

Example 2: Choosing among multiple ASes now suppose AS1 learns from inter-as protocol that subnet x is reachable from AS3 and from AS2. to configure forwarding table, router 1d must determine towards which gateway it should forward packets for dest x. this is also job of inter-as routing protocol! 3c 3a 3b AS3 1a 1c 1d x 1b AS1 2a 2c 2b AS2 Network Layer 4-30

Example 2: Choosing among multiple ASes now suppose AS1 learns from inter-as protocol that subnet x is reachable from AS3 and from AS2. to configure forwarding table, router 1d must determine towards which gateway it should forward packets for dest x. this is also job of inter-as routing protocol! hot potato routing: send packet towards closest of two routers. Learn from inter-as protocol that subnet x is reachable via multiple gateways Use routing info from intra-as protocol to determine costs of least-cost paths to each of the gateways Hot potato routing: Choose the gateway that has the smallest least cost Determine from forwarding table the interface I that leads to least-cost gateway. Enter (x,i) in forwarding table Network Layer 4-31

Chapter 4: 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 Network Layer 4-32

Intra-AS Routing also known as Interior Gateway Protocols (IGP) most common Intra-AS routing protocols: RIP: Routing Information Protocol OSPF: Open Shortest Path First IGRP: Interior Gateway Routing Protocol (Cisco proprietary) Network Layer 4-33

Chapter 4: 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 Network Layer 4-34

RIP (Routing Information Protocol) Distance vector algorithm, with poisoned-reverse Distance metric: # of hops max = 15 hops (16 = infinity) w x y A D B z Destination Network C Next Router Num. of hops to dest. w A 2 y B 2 z B 7 x -- 1..... Routing table in D Distance vectors: advertised every 30 sec (no advertisement heard after 180 sec --> neighbor/link declared dead) 4: Network Layer 4b- 35

RIP Table processing RIP routing tables managed by application-level process called route-d (daemon) advertisements sent in UDP packets, periodically repeated 4: Network Layer 4b- 36

Chapter 4: 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 Network Layer 4-37

OSPF (Open Shortest Path First) open : publicly available Uses Link State algorithm (configurable edge-costs) Advertisements disseminated to entire AS (via flooding), via IP packets (unlike RIP) OSPF advanced features (Note: features of the standardized protocol, not the algorithm) -not in RIP Security: all OSPF messages authenticated (to prevent malicious intrusion) Multiple same-cost paths allowed (only one path in RIP) multiple cost metrics for different TypeOfService (eg, satellite link cost low for best effort; high for real time) Integrated uni- and multicast support: Multicast OSPF (MOSPF) uses same topology data base as OSPF Hierarchical OSPF in large domains. 4: Network Layer 4b- 38

Hierarchical OSPF 4: Network Layer 4b- 39

Hierarchical OSPF Two-level hierarchy: local area, backbone. Link-state advertisements only in area each node has detailed area topology; only know direction (shortest path) to nets in other areas. Area border routers: summarize distances to nets in own area, advertise to other Area Border routers. Backbone routers: run OSPF routing limited to backbone. Boundary routers: connect to other ASs. 4: Network Layer 4b- 40

Chapter 4: 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 Network Layer 4-41

Internet inter-as routing: BGP BGP (Border Gateway Protocol): the de facto standard BGP provides each AS a means to: 1. Obtain subnet reachability information from neighboring ASs. 2. Propagate reachability information to all ASinternal routers. 3. Determine good routes to subnets based on reachability information and policy. allows subnet to advertise its existence to rest of Internet: I am here Network Layer 4-42

BGP basics pairs of routers (BGP peers) exchange routing info over semi-permanent TCP connections: BGP sessions External, internal: ebgp, ibgp BGP sessions need not correspond to physical links. when AS2 advertises a prefix (e.g. subnet) to AS1: AS2 promises it will forward datagrams towards that prefix. AS2 can aggregate prefixes in its advertisement 3c 3a 3b AS3 1a AS1 1c 1d ebgp session ibgp session 1b 2a 2c 2b AS2 Network Layer 4-43

Distributing reachability info using ebgp session between 3a and 1c, AS3 sends prefix reachability info to AS1. 1c can then use ibgp do distribute new prefix info to all routers in AS1 1b can then re-advertise new reachability info to AS2 over 1b-to-2a ebgp session when router learns of new prefix, it creates entry for prefix in its forwarding table. 3c 3a 3b AS3 1a AS1 1c 1d ebgp session ibgp session 1b 2a 2c 2b AS2 Network Layer 4-44

BGP: routing Path Vector protocol (similar to Distance Vector): each Border Gateway advertises entire path (I.e, sequence of ASs) to destination Suppose: gateway X send its path to peer gateway W W may or may not select path offered by X cost, policy (don t route via competitor s AS), loop prevention reasons. If W selects path advertised by X, then: Path (W,Z) = w, Path (X,Z) Note: X can control incoming traffic by controling its route advertisements to peers: e.g., don t want to route traffic to Z -> don t advertise any routes to Z 4: Network Layer 4b- 45

Path attributes & BGP routes advertised prefix includes BGP attributes. prefix + attributes = route two important attributes: AS-PATH: contains ASs through which prefix advertisement has passed: e.g, AS 67, AS 17 NEXT-HOP: indicates specific internal-as router to next-hop AS. (may be multiple links from current AS to next-hop-as) when gateway router receives route advertisement, uses import policy to accept/decline. Network Layer 4-46

BGP route selection router may learn about more than 1 route to some prefix. Router must select route. elimination rules: 1. local preference value attribute: policy decision 2. shortest AS-PATH 3. closest NEXT-HOP router: hot potato routing 4. additional criteria Network Layer 4-47

BGP messages BGP messages exchanged using TCP. BGP messages: OPEN: opens TCP connection to peer and authenticates sender UPDATE: advertises new path (or withdraws old) KEEPALIVE keeps connection alive in absence of UPDATES; also ACKs OPEN request NOTIFICATION: reports errors in previous msg; also used to close connection Network Layer 4-48

BGP routing policy: example W A B C X legend: provider network customer network: Y A,B,C are provider networks X,W,Y are customer (of provider networks) X is dual-homed: attached to two networks X does not want to route from B via X to C.. so X will not advertise to B a route to C Network Layer 4-49

BGP routing policy: example (cont) W A B C X legend: provider network customer network: Y A advertises path AW to B B advertises path BAW to X Should B advertise path BAW to C? No way! B gets no revenue for routing CBAW since neither W nor C are B s customers B wants to force C to route to w via A B wants to route only to/from its customers! Network Layer 4-50

Why different Intra- and Inter-AS routing? Policy: Inter-AS: admin wants control over how its traffic routed, who routes through its net. Intra-AS: single admin, so no policy decisions needed Scale: hierarchical routing saves table size, reduced update traffic Performance: Intra-AS: can focus on performance Inter-AS: policy may dominate over performance Network Layer 4-51

Chapter 4: 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 Network Layer 4-52

Review questions for this part Most commonly used routing protocols in the Internet? What algorithms they use? Why? What else besides algorithms choices is important? (hint: think about policies) Why? Network Layer 4-53