PowerPoint version
Download
Report
Transcript PowerPoint version
Network Layer: Routing & Forwarding
Instructor: Carey Williamson
Office: ICT 740
Email: [email protected]
Class Location: ICT 122
Lectures: MWF 12:00 – 12:50
Notes derived from “Computer Networking: A Top
Down Approach”, by Jim Kurose and Keith Ross,
Addison-Wesley.
Slides are adapted from the book’s companion Web site,
with changes by Anirban Mahanti and Carey Williamson.
Forwarding
1
Key Network-Layer Functions
forwarding: move packets from router’s input
to appropriate router output
routing: determine the path taken by packets
as they flow from a sender to a receiver
Routing algorithms – run at routers to determine
“paths”;
Routers
have a forwarding table
• Destination address-based in Datagram networks
• Virtual circuit number-based in VC Networks
Forwarding
2
Interplay between routing and 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
1
3 2
Forwarding
3
VC Networks: Connection setup
3rd important function in some network
architectures:
ATM, frame relay, X.25
Before datagrams flow, two hosts and
intervening routers establish virtual
connection
Routers get involved
Network and transport layer conn service:
Network: between two hosts
Transport: between two processes
Forwarding
4
Network service model
Q: What service model for the “channel”
transporting datagrams from sender to receiver?
Example services for
individual datagrams:
Guaranteed delivery
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 interpacket spacing
Forwarding
5
Network layer service models:
Network
Architecture
Internet
Service
Model
Guarantees ?
Congestion
Bandwidth Loss Order Timing feedback
best effort none
ATM
CBR
ATM
VBR
ATM
ABR
ATM
UBR
constant
rate
guaranteed
rate
guaranteed
minimum
none
no
no
no
yes
yes
yes
yes
yes
yes
no
yes
no
no (inferred
via loss)
no
congestion
no
congestion
yes
no
yes
no
no
Forwarding
6
Network layer connection-oriented
and connection-less service
Datagram network provides network-layer
connectionless service
VC network provides network-layer
connection-oriented service
Analogous to the transport-layer services,
but:
Service: host-to-host
No choice: network provides one or the other
Implementation: in the core
Forwarding
7
Virtual circuits
“source-to-dest path behaves much like telephone
circuit”
performance-wise
network actions along source-to-dest path
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
Forwarding
8
VC implementation
A VC consists of:
1.
2.
3.
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 a VC
number.
VC number must be changed on each link.
New VC number comes from forwarding table
Forwarding
9
Forwarding table
VC number
22
12
1
Forwarding table in
Northwest router:
Incoming interface
1
2
3
1
…
2
32
3
interface
number
Incoming VC #
12
63
7
97
…
Outgoing interface
3
1
2
3
…
Outgoing VC #
22
18
17
87
…
Routers maintain connection state information!
Forwarding
10
Virtual circuits: signaling protocols
used to setup, maintain, and teardown VC
used in ATM, frame-relay, X.25
not used in today’s Internet
application
transport 5. Data flow begins
network 4. Call connected
data link 1. Initiate call
physical
6. Receive data application
3. Accept call
2. incoming call
transport
network
data link
physical
Forwarding
11
Datagram networks
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-dest pair may take
different paths
application
transport
network
data link 1. Send data
physical
application
transport
network
2. Receive data
data link
physical
Forwarding
12
Datagram or VC network: why?
Internet
data exchange among
ATM
evolved from telephony
computers
human conversation:
“elastic” service, no strict
strict timing, reliability
timing req.
requirements
“smart” end systems
need for guaranteed
(computers)
service
can adapt, perform
“dumb” end systems
control, error recovery
telephones
simple inside network,
complexity inside
complexity at “edge”
network
many link types
different characteristics
uniform service difficult
Forwarding
13
Inside a Router
Forwarding
14
Router Architecture Overview
Two key router functions:
run routing algorithms/protocol (RIP, OSPF, BGP)
forwarding datagrams from incoming to outgoing link
Forwarding
15
Input Port Functions
Physical layer:
bit-level reception
Data link layer:
e.g., Ethernet
Decentralized switching:
given datagram dest., lookup output port
using forwarding table in input port
memory (caching of entries)
goal: complete input port processing at
‘line speed’
queuing: if datagrams arrive faster than
forwarding rate into switch fabric
Forwarding
16
Three types of switching fabrics
Forwarding
17
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)
Input
Port
Memory
Output
Port
System Bus
Forwarding
18
Switching via a Bus
datagram from input port memory
to output port memory via a shared
bus
bus contention: switching speed
limited by bus bandwidth
1 Gbps bus, Cisco 1900: sufficient
speed for access and enterprise
routers (not regional or backbone)
Forwarding
19
Switching via an Interconnection
Network
Overcomes bus bandwidth limitations
Banyan networks, other interconnection nets
initially developed to connect processors in
multiprocessor
Advanced design: fragmenting datagram into fixed
length cells, switch cells through the fabric.
Cisco 12000: switches Gbps through the
interconnection network
Forwarding
20
Output Ports
Buffering required when datagrams arrive from
fabric faster than the transmission rate
Need queue management policy (Drop-Tail, AQM)
Also need packet scheduling policy (FCFS, WFQ)
Forwarding
21
Output port queueing
buffering when arrival rate via switch exceeds
output line speed
queueing (delay) and loss due to output port
buffer overflow!
Forwarding
22
Input Port Queuing?
Fabric slower than input ports combined -> queueing
may occur at input queues
Head-of-the-Line (HOL) blocking: queued datagram
at front of queue prevents others in queue from
moving forward (even though o/p port is free for the
other datagram)
Forwarding
23
Next Topic
Routing Algorithms
Routing in the Internet
Readings: Chapter 4 in the K&R book
Forwarding
24