+ All Categories
Home > Documents > 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW...

1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW...

Date post: 29-Mar-2015
Category:
Upload: keshawn-garrison
View: 214 times
Download: 2 times
Share this document with a friend
Popular Tags:
35
1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant: Mike Wawrzoniak http://www.cs.princeton.edu/courses/archive/spring06/ cos461/
Transcript
Page 1: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

1

Shortest-Path RoutingReading: Sections 4.2 and 4.3.4

COS 461: Computer Networks

Spring 2006 (MW 1:30-2:50 in Friend 109)

Jennifer Rexford

Teaching Assistant: Mike Wawrzoniak http://www.cs.princeton.edu/courses/archive/spring06/cos461/

Page 2: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

2

Goals of Today’s Lecture

• Path selection–Minimum-hop and shortest-path routing–Dijkstra and Bellman-Ford algorithms

• Topology change–Using beacons to detect topology changes–Propagating topology or path information

• Routing protocols–Link state: Open Shortest Path First–Distance vector: Routing Information Protocol

Page 3: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

3

What is Routing?

• A famous quotation from RFC 791 “A name indicates what we seek.An address indicates where it is.A route indicates how we get there.” -- Jon Postel

Page 4: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

4

Forwarding vs. Routing

• Forwarding: data plane–Directing a data packet to an outgoing link–Individual router using a forwarding table

• Routing: control plane–Computing paths the packets will follow–Routers talking amongst themselves–Individual router creating a forwarding table

Page 5: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

5

Why Does Routing Matter?

• End-to-end performance–Quality of the path affects user performance–Propagation delay, throughput, and packet loss

• Use of network resources–Balance of the traffic over the routers and links–Avoiding congestion by directing traffic to lightly-

loaded links

• Transient disruptions during changes–Failures, maintenance, and load balancing–Limiting packet loss and delay during changes

Page 6: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

6

Shortest-Path Routing

• Path-selection model–Destination-based–Load-insensitive (e.g., static link weights)–Minimum hop count or sum of link weights

32

2

1

14

1

4

5

3

Page 7: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

7

Shortest-Path Problem

• Given: network topology with link costs– c(x,y): link cost from node x to node y– Infinity if x and y are not direct neighbors

• Compute: least-cost paths to all nodes– From a given source u to all other nodes– p(v): predecessor node along path from source to v

32

2

1

14

1

4

5

3

u

v

p(v)

Page 8: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

8

Dijkstra’s Shortest-Path Algorithm

• Iterative algorithm– After k iterations, know least-cost path to k nodes

• S: nodes whose least-cost path definitively known– Initially, S = {u} where u is the source node– Add one node to S in each iteration

• D(v): current cost of path from source to node v– Initially, D(v) = c(u,v) for all nodes v adjacent to u– … and D(v) = ∞ for all other nodes v– Continually update D(v) as shorter paths are learned

Page 9: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

9

Dijsktra’s Algorithm

1 Initialization: 2 S = {u} 3 for all nodes v 4 if v adjacent to u {5 D(v) = c(u,v) 6 else D(v) = ∞ 7 8 Loop 9 find w not in S with the smallest D(w)10 add w to S 11 update D(v) for all v adjacent to w and not in S: 12 D(v) = min{D(v), D(w) + c(w,v)} 13 until all nodes in S

Page 10: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

10

Dijkstra’s Algorithm Example

32

2

1

14

1

4

5

3

32

2

1

14

1

4

5

3

32

2

1

14

1

4

5

3

32

2

1

14

1

4

5

3

Page 11: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

11

Dijkstra’s Algorithm Example

32

2

1

14

1

4

5

3

32

2

1

14

1

4

5

3

32

2

1

14

1

4

5

3

32

2

1

14

1

4

5

3

Page 12: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

12

Shortest-Path Tree

• Shortest-path tree from u • Forwarding table at u

32

2

1

14

1

4

5

3

u

v

w

x

y

z

s

t

v (u,v)w (u,w)x (u,w)y (u,v)z (u,v)

link

s (u,w)t (u,w)

Page 13: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

13

Link-State Routing

• Each router keeps track of its incident links– Whether the link is up or down– The cost on the link

• Each router broadcasts the link state– To give every router a complete view of the graph

• Each router runs Dijkstra’s algorithm– To compute the shortest paths– … and construct the forwarding table

• Example protocols– Open Shortest Path First (OSPF)– Intermediate System – Intermediate System (IS-IS)

Page 14: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

14

Detecting Topology Changes

• Beaconing–Periodic “hello” messages in both directions–Detect a failure after a few missed “hellos”

• Performance trade-offs–Detection speed–Overhead on link bandwidth and CPU–Likelihood of false detection

“hello”

Page 15: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

15

Broadcasting the Link State

• Flooding–Node sends link-state information out its links–And then the next node sends out all of its links–… except the one where the information arrived

X A

C B D

(a)

X A

C B D

(b)

X A

C B D

(c)

X A

C B D

(d)

Page 16: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

16

Broadcasting the Link State

• Reliable flooding–Ensure all nodes receive link-state information–… and that they use the latest version

• Challenges–Packet loss–Out-of-order arrival

• Solutions–Acknowledgments and retransmissions–Sequence numbers–Time-to-live for each packet

Page 17: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

17

When to Initiate Flooding

• Topology change–Link or node failure–Link or node recovery

• Configuration change–Link cost change

• Periodically–Refresh the link-state information–Typically (say) 30 minutes–Corrects for possible corruption of the data

Page 18: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

18

Convergence

• Getting consistent routing information to all nodes– E.g., all nodes having the same link-state database

• Consistent forwarding after convergence– All nodes have the same link-state database– All nodes forward packets on shortest paths– The next router on the path forwards to the next hop

32

2

1

14

1

4

5

3

Page 19: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

19

Transient Disruptions

• Detection delay–A node does not detect a failed link immediately–… and forwards data packets into a “blackhole”–Depends on timeout for detecting lost hellos

32

2

1

14

1

4

5

3

Page 20: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

20

Transient Disruptions

• Inconsistent link-state database–Some routers know about failure before others–The shortest paths are no longer consistent–Can cause transient forwarding loops

32

2

1

14

1

4

5

3

32

2

1

14

1

4 3

Page 21: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

21

Convergence Delay

• Sources of convergence delay–Detection latency–Flooding of link-state information–Shortest-path computation–Creating the forwarding table

• Performance during convergence period–Lost packets due to blackholes and TTL expiry–Looping packets consuming resources–Out-of-order packets reaching the destination

• Very bad for VoIP, online gaming, and video

Page 22: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

22

Reducing Convergence Delay

• Faster detection– Smaller hello timers– Link-layer technologies that can detect failures

• Faster flooding– Flooding immediately– Sending link-state packets with high-priority

• Faster computation– Faster processors on the routers– Incremental Dijkstra algorithm

• Faster forwarding-table update– Data structures supporting incremental updates

Page 23: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

23

Scaling Link-State Routing

• Overhead of link-state routing– Flooding link-state packets throughout the network– Running Dijkstra’s shortest-path algorithm

• Introducing hierarchy through “areas”

Area 0

Area 1 Area 2

Area 3 Area 4

areaborderrouter

Page 24: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

24

Bellman-Ford Algorithm

• Define distances at each node x– dx(y) = cost of least-cost path from x to y

• Update distances based on neighbors– dx(y) = min {c(x,v) + dv(y)} over all neighbors v

32

2

1

14

1

4

5

3

u

v

w

x

y

z

s

t du(z) = min{c(u,v) + dv(z), c(u,w) + dw(z)}

Page 25: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

25

Distance Vector Algorithm

• c(x,v) = cost for direct link from x to v– Node x maintains costs of direct links c(x,v)

• Dx(y) = estimate of least cost from x to y– Node x maintains distance vector Dx = [Dx(y): y є N ]

• Node x maintains its neighbors’ distance vectors– For each neighbor v, x maintains Dv = [Dv(y): y є N ]

• Each node v periodically sends Dv to its neighbors– And neighbors update their own distance vectors– Dx(y) ← minv{c(x,v) + Dv(y)} for each node y N∊

• Over time, the distance vector Dx converges

Page 26: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

26

Distance Vector Algorithm

Iterative, asynchronous: each local iteration caused by:

• Local link cost change

• Distance vector update message from neighbor

Distributed:

• Each node notifies neighbors only when its DV changes

• Neighbors then notify their neighbors if necessary

wait for (change in local link cost or message from neighbor)

recompute estimates

if DV to any destination has

changed, notify neighbors

Each node:

Page 27: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

27

Distance Vector Example: Step 0

A

E

F

C

D

B

2

3

6

4

1

1

1

3

Table for A

Dst Cst Hop

A 0 A

B 4 B

C –

D –

E 2 E

F 6 F

Table for B

Dst Cst Hop

A 4 A

B 0 B

C –

D 3 D

E –

F 1 F

Table for C

Dst Cst Hop

A –

B –

C 0 C

D 1 D

E –

F 1 F

Table for D

Dst Cst Hop

A –

B 3 B

C 1 C

D 0 D

E –

F –

Table for E

Dst Cst Hop

A 2 A

B –

C –

D –

E 0 E

F 3 F

Table for F

Dst Cst Hop

A 6 A

B 1 B

C 1 C

D –

E 3 E

F 0 F

Optimum 1-hop paths

Page 28: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

28

Distance Vector Example: Step 2

Table for A

Dst Cst Hop

A 0 A

B 4 B

C 7 F

D 7 B

E 2 E

F 5 E

Table for B

Dst Cst Hop

A 4 A

B 0 B

C 2 F

D 3 D

E 4 F

F 1 F

Table for C

Dst Cst Hop

A 7 F

B 2 F

C 0 C

D 1 D

E 4 F

F 1 F

Table for D

Dst Cst Hop

A 7 B

B 3 B

C 1 C

D 0 D

E –

F 2 C

Table for E

Dst Cst Hop

A 2 A

B 4 F

C 4 F

D –

E 0 E

F 3 F

Table for F

Dst Cst Hop

A 5 B

B 1 B

C 1 C

D 2 C

E 3 E

F 0 F

Optimum 2-hop paths

A

E

F

C

D

B

2

3

6

4

1

1

1

3

Page 29: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

29

Distance Vector Example: Step 3

Table for A

Dst Cst Hop

A 0 A

B 4 B

C 6 E

D 7 B

E 2 E

F 5 E

Table for B

Dst Cst Hop

A 4 A

B 0 B

C 2 F

D 3 D

E 4 F

F 1 F

Table for C

Dst Cst Hop

A 6 F

B 2 F

C 0 C

D 1 D

E 4 F

F 1 F

Table for D

Dst Cst Hop

A 7 B

B 3 B

C 1 C

D 0 D

E 5 C

F 2 C

Table for E

Dst Cst Hop

A 2 A

B 4 F

C 4 F

D 5 F

E 0 E

F 3 F

Table for F

Dst Cst Hop

A 5 B

B 1 B

C 1 C

D 2 C

E 3 E

F 0 F

Optimum 3-hop paths

A

E

F

C

D

B

2

3

6

4

1

1

1

3

Page 30: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

30

Distance Vector: Link Cost Changes

Link cost changes:

• Node detects local link cost change

• Updates the distance table

• If cost change in least cost path, notify neighbors

X Z14

50

Y1

algorithmterminates“good

news travelsfast”

Page 31: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

31

Distance Vector: Link Cost Changes

Link cost changes:

• Good news travels fast

• Bad news travels slow - “count to infinity” problem!

X Z14

50

Y60

algorithmcontinues

on!

Page 32: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

32

Distance Vector: Poison 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)

• Still, can have problems when more than 2 routers are involved

X Z14

50

Y60

algorithmterminates

Page 33: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

33

Routing Information Protocol (RIP)

• Distance vector protocol– Nodes send distance vectors every 30 seconds– … or, when an update causes a change in routing

• Link costs in RIP– All links have cost 1– Valid distances of 1 through 15– … with 16 representing infinity– Small “infinity” smaller “counting to infinity” problem

• RIP is limited to fairly small networks– E.g., used in the Princeton campus network

Page 34: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

34

Comparison of LS and DV algorithms

Message complexity

• LS: with n nodes, E links, O(nE) messages sent

• DV: exchange between neighbors only– Convergence time varies

Speed of Convergence

• LS: O(n2) algorithm requires O(nE) messages

• DV: convergence time varies– May be routing loops– Count-to-infinity problem

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 (error propagates)

Page 35: 1 Shortest-Path Routing Reading: Sections 4.2 and 4.3.4 COS 461: Computer Networks Spring 2006 (MW 1:30-2:50 in Friend 109) Jennifer Rexford Teaching Assistant:

35

Conclusions

• Routing is a distributed algorithm– React to changes in the topology– Compute the shortest paths

• Two main shortest-path algorithms– Dijkstra link-state routing (e.g., OSPF and IS-IS)– Bellman-Ford distance vector routing (e.g., RIP)

• Convergence process– Changing from one topology to another– Transient periods of inconsistency across routers

• Next time: policy-based path-vector routing– Reading: Section 4.3.3


Recommended