CSE123A discussion session 2007/03/08 Ryo Sugihara
Topics Review –Network Layer (2,3): Route computation Distance vector Link state
Where are we now?
Route computation Router needs to know “which port to forward” –Done by “routing table” But how to make routing table? –By exchanging routing information –What kind of information? Router A B C D PrefixLink 001*A 0*B 01*C 11*C 110*D defaultB Routing table
Distance vector & Link state Two ways to exchange routing info –Distance vector Exchange “distance to a destination” Each router knows the next hop for each dest –One hop of the stortest path to the dest –Link state Exchange “my neighbors (and costs)” Each router knows whole network topology –compute the shortest paths by Dijkstra’s algorithm
Example R1 R2 R3 R4 R CSE ( /24) 1
General strategy R1 (somehow) knows CSE is distance one from itself R1 tells the neighbors (=R2, R3) about it –DV: “CSE is distance one from me” –LS: “I have link with CSE (d=1), R2 (d=5), and R3 (d=1)” R1 R2 R3 R4 R CSE 1
Distance vector R1 tells “CSE is distance one from me!” –to R2 and R3 R1 R2 R3 R4 R CSE “CSE = 1” 1
What happens at R2? p1 p2 p3 “CSE = 1” R2 Netdist... CSE6... Netdist... CSEinf... Netdist... CSEinf... Netdist... CSE6... iface... p1... Routing table Table for each interface One routing table
Distance vector Router forwards distance info to others when its routing table is updated R1 R2 R3 R4 R CSE “CSE = 6” “CSE = 2” “CSE = 6” 1
What happens at R2? p1 p2 p3 R2 Netdist... CSE6... Netdist... CSE4... Netdist... CSEinf... Netdist... CSE6... iface... p1... “CSE = 2” 4p2 Routing table
In case of link failure, Switch to backup route Problem: “Count-to-infinity problem” (next) p1 p2 p3 R2 Netdist... CSE6... Netdist... CSE4... Netdist... CSEinf... Netdist... CSE4... iface... p2... Routing table inf 6 p1
Count-to-infinity problem R CSE p1 p2 p3 p4 Netdist CSE2 Netdist CSE6 Netdist CSE2 iface p3 Routing table Netdist CSE3 Netdist CSE5 Netdist CSE3 iface p1 Routing table inf 5 p26 p4 “CSE = 5” 8 8 p4 “CSE = 8” p2 R2 R3 1
Link state R1 broadcasts “I have link with CSE (d=1), R2 (d=5), and R3 (d=1)” –It will be flooded to the entire network R1 R2 R3 R4 R CSE LSP R1 R2 R3 CSE LSP = 1
Link state Each router has the entire graph –In DV, it only knew next hop for each dest. Each router computes next hop for each dest. –By Dijkstra’s algorithm R1 R2 R3 R4 R CSE 1
Intelligent flooding Without “intelligence”, LSP may loop Solution: add “sequence number” to LSP –If a router received a “newer” LSP, it forwards –Otherwise, it discards Other issues: –Subtle problems: “source jumping”, “aging” lecture notes –How Dijkstra’s algorithm works R1 R2 R3 R4 R CSE LSP 1
BACKUP