Internet Communications, Networking & Computer Security (Adapted from Kurose – Networking) Sanjay Goel University at Albany Sanjay Goel, School of Business 1 Routing Sanjay Goel, School of Business 2 World Wide Web Protocols Web Browser Application Layer HTTP Message Web Server Application Layer Transport Layer Transport Layer TCP Packet Internet Layer Internet Layer IP Datagram Network Layer Ethernet Frame Network Layer Physical Network • The data may be routed via numerous nodes called routers Sanjay Goel, School of Business 3 Routing Protocols Host A Application Layer Host B Application Layer Message Transport Layer Router Network Layer Network Layer Datagram Link Layer Network Layer Datagram Link Layer Frame Physical Network • Transport Layer Packet Link Layer Frame Physical Network The data may be routed via numerous nodes called routers Sanjay Goel, School of Business 4 Routing Protocols • In TCP/IP any machine on the same network can be contacted directly, but machines on another network must be contacted through a router or gateway. • Router is a specific device (software or hardware) that forwards a transmission from a local network to other networks. • Since the router is another device on the network, it needs to have its own internal IP address that the computers can contact. Router Network A Network B Web Browser Web Server Sanjay Goel, School of Business 5 Routing Protocols • Objective: Determining optimum path through a sequence of routers that packets should take in going from one host to destination • Graph abstraction for routing algorithms: – – – Graph nodes are routers Graph edges are physical links link cost: delay, $ cost, or congestion level 3 B C 5 2 A 2 1 D Sanjay Goel, School of Business 1 3 1 E F 2 6 Routing Algorithms • • Logic for deciding the path Two kinds of routing algorithms – – • Link State Algorithm: Global routing algorithm that uses knowledge of the entire network while making selection Distance Vector Algorithm: Decentralized algorithm compues least cost path in iterative distributed manner The routing algorithms can also be classified as – – Static: Routes change slowly over time (usually via manual intervention) Dynamic: Routing paths change as network traffic loads or network topology changes. Sanjay Goel, School of Business 7 Routing Dijkstra’s Algorithm • Net topology, link costs known to all nodes – – • Computes least cost paths from one node (‘source”) to all other nodes – • • accomplished via “link state broadcast” all nodes have same info gives routing table for that node iterative: after k iterations, know least cost path to k dest.’s Notation: – – – – c(i,j): link cost from node i to j. cost infinite 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, that is next v N: set of nodes whose least cost path definitively known Sanjay Goel, School of Business 8 Routing Dijkstra’s Algorithm - Steps • Algorithm complexity (n nodes) Initialization: – each iteration: need to check all N = {A} nodes, w, not in N for all nodes v { – n*(n+1)/2 comparisons: O(n**2) if v adjacent to A – Efficient implementations O(nlogn) then D(v) = c(A,v) possible else D(v) = infty } Loop (until all nodes in N) { find w not in N such that D(w) is a minimum add w to N update D(v) for all v adjacent to w and not in N: D(v) = min( D(v), D(w) + c(w,v) ) /* new cost to v is either old cost to v or known shortest path cost to w plus cost from w to v */ } Sanjay Goel, School of Business 9 Routing Dijkstra’s Algorithm - Example Step 0 1 2 3 4 5 start N A AD ADE ADEB ADEBC ADEBCF Node Distance A - B 2 C 3 D 1 E 2 F 4 Sanjay Goel, School of Business D(B),p(B) D(C),p(C) D(D),p(D) D(E),p(E) D(F),p(F) 2,A 1,A 5,A infinity infinity 2,A 4,D 2,D infinity 2,A 3,E 4,E 3,E 4,E 4,E Compute Distance Vector for node A 5 3 B C 2 A 2 1 D 1 3 1 E 5 F 2 10 Routing Dijkstra’s Algorithm - Problem 1 B C 5 10 3 A 5 Sanjay Goel, School of Business 6 4 5 D 2 E F 6 11 Routing Distance Vector Algorithm • • • Each router starts with a distance table consisting of the value “0” for itself and the value “infinity” for every other destination Each router will transmit its distance vector to each of its neighbors whenever the information changes (as well as when a link to a neighbor first comes up) Each router saves the most recently received distance vector from each of its neighbors, and calculate its own distance vector, based on minimizing the cost to each destination Sanjay Goel, School of Business 12 Routing Distance Vector Algorithm (Kurose) iterative: continues until no nodes exchange info. self-terminating: no “signal” to stop asynchronous: nodes need not exchange info/iterate in lock step! distributed: each node communicates only with directly-attached neighbors Sanjay Goel, School of Business Distance Table data structure each node has its own row for each possible destination column for each directly-attached neighbor to node example: in node X, for dest. Y via neighbor Z: X D (Y,Z) distance from X to = Y, via Z as next hop = c(X,Z) + min {DZ(Y,w)} w 13 Routing Distance Table (Example) 7 A B 1 C E cost to destination via D () A B D A 1 14 5 B 7 8 5 C 6 9 4 D 4 11 2 2 8 1 E 2 D E D (C,D) = c(E,D) + min {DD(C,w)} = 2+2 = 4 w E D (A,D) = c(E,D) + min {DD(A,w)} E w = 2+3 = 5 loop! D (A,B) = c(E,B) + min {D B(A,w)} = 8+6 = 14 Sanjay Goel, School of Business w loop! 14 Routing Distance Table Gives Routing Table E cost to destination via Outgoing link D () A B D A 1 14 5 A A,1 B 7 8 5 B D,5 C 6 9 4 C D,4 D 4 11 2 D D,4 Distance table Sanjay Goel, School of Business to use, cost Routing table 15 Distance Routing Overview Iterative, asynchronous: each local iteration caused by: local link cost change message from neighbor: its least cost path change from neighbor Distributed: each node notifies neighbors only when its least cost path to any destination changes – neighbors then notify their neighbors if necessary Sanjay Goel, School of Business Each node: wait for (change in local link cost of msg from neighbor) recompute distance table if least cost path to any dest has changed, notify neighbors 16 Distance Routing Distance Vector Algorithm At all nodes, X: 1 Initialization: 2 for all adjacent nodes v: 3 D X(*,v) = infty /* the * operator means "for all rows" */ 4 D X(v,v) = c(X,v) 5 for all destinations, y 6 send min D X(y,w) to each neighbor /* w over all X's neighbors */ w Sanjay Goel, School of Business 17 Distance Routing Distance Vector Algorithm Cont’ 8 loop 9 wait (until I see a link cost change to neighbor V 10 or until I receive update from neighbor V) 11 12 if (c(X,V) changes by d) 13 /* change cost to all dest's via neighbor v by d */ 14 /* note: d could be positive or negative */ 15 for all destinations y: D X(y,V) = D X(y,V) + d 16 17 else if (update received from V wrt destination Y) 18 /* shortest path from V to some Y has changed */ 19 /* V has sent a new value for its min DV(Y,w) */ w 20 /* call this received new value is "newval" */ 21 for the single destination y: D X(Y,V) = c(X,V) + newval 22 23 if we have a new min DX(Y,w)for any destination Y w 24 send new value of min D X(Y,w) to all neighbors w 26 forever Sanjay Goel, School of Business 18 Distance Routing Distance Vector Algorithm Example: X 2 Y 7 1 Z Sanjay Goel, School of Business 19 Distance Routing Distance Vector Algorithm Example: X 2 Y 7 1 Z X Z X Y D (Y,Z) = c(X,Z) + minw{D (Y,w)} = 7+1 = 8 D (Z,Y) = c(X,Y) + minw {D (Z,w)} = 2+1 = 3 Sanjay Goel, School of Business 20 Distance Routing Distance Vector Algorithm: Link Cost Changes Link cost changes: • node detects local link cost change • updates distance table (line 15) • if cost change in least cost path, notify neighbors (lines 23,24) “good news travels fast” Sanjay Goel, School of Business 1 X 4 Y 50 1 Z algorithm terminates 21 Distance Routing Distance Vector Algorithm: Example Count to infinity A B 1 Sanjay Goel, School of Business C 1 22 Distance Routing Distance Vector Algorithm: Link Cost Changes Link cost changes: • good news travels fast • bad news travels slow “count to infinity” problem! Sanjay Goel, School of Business 60 X 4 Y 50 1 Z algorithm continues on! 23 Distance Routing Distance Vector Algorithm: Position 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) • will this completely solve count to infinity problem? Sanjay Goel, School of Business 60 X 4 Y 50 1 Z algorithm terminates 24 Distance Routing Comparison of LS & DV Message complexity LS: with n nodes, E links, O(nE) msgs sent each DV: exchange between neighbors only – convergence time varies Speed of Convergence LS: O(n**2) algorithm requires O(nE) msgs – may have oscillations DV: convergence time varies – may be routing loops – count-to-infinity problem Sanjay Goel, School of Business Robustness: what happens if router malfunctions? LS: – node can advertise incorrect link cost – each node computes only its own table DV: – DV node can advertise incorrect path cost – each node’s table used by others o error propagate thru network 25 Routing Algorithms Summary • LS and DV are representative • There are other type of routing algorithms, especially in circuit switching world, e.g., hot potato algorithm • Most of the internet routing protocols (think OSPF, BGP etc.) are based on these fundamental algorithms we introduced just now Sanjay Goel, School of Business 26