Beruflich Dokumente
Kultur Dokumente
value in arriving
packet’s header
0111 1
3 2
Connection setup
• 3rd important function in some network
architectures:
– ATM, frame relay, X.25
• before datagrams flow, two end hosts and
intervening routers establish virtual connection
– routers get involved
• network vs transport layer connection service:
– network: between two hosts (may also involve
intervening routers in case of VCs)
– transport: between two processes
Network service model
Q: What service model for “channel” transporting
datagrams from sender to receiver?
application application
transport transport
network 1. send datagrams 2. receive datagrams network
data link data link
physical physical
Datagram forwarding table
4 billion IP addresses, so
routing algorithm rather than list individual
destination address
local forwarding table
list range of addresses
dest address output link (aggregate table entries)
address-range 1 3
address-range 2 2
address-range 3 2
address-range 4 1
IP destination address in
arriving packet’s header
1
3 2
Datagram forwarding table
Destination Address Range Link Interface
otherwise 3
examples:
DA: 11001000 00010111 00010110 10100001 which interface?
DA: 11001000 00010111 00011000 10101010 which interface?
Datagram or VC network: why?
Internet (datagram) ATM (VC)
• data exchange among • evolved from telephony
computers • human conversation:
– “elastic” service, no strict – strict timing, reliability
timing req. requirements
– need for guaranteed
• many link types service
– different characteristics • “dumb” end systems
– uniform service difficult – telephones
• “smart” end systems – complexity inside network
(computers)
– can adapt, perform control,
error recovery
– simple inside network,
complexity at “edge”
Router architecture overview
two key router functions:
run routing algorithms/protocol (RIP, OSPF, BGP)
forwarding datagrams from incoming to outgoing link
forwarding data
plane (hardware)
high-seed
switching
fabric
lookup,
link forwarding
line layer switch
termination protocol fabric
(receive)
queueing
physical layer:
bit-level reception
data link layer: decentralized switching:
e.g., Ethernet • given datagram dest., lookup output port
see chapter 5 using forwarding table in input port
memory (“match plus action”)
• goal: complete input port processing at
‘line speed’
• queuing: if datagrams arrive faster than
forwarding rate into switch fabric
Network Layer 4-15
Switching fabrics
transfer packet from input buffer to appropriate output
buffer
switching rate: rate at which packets can be transfer from
inputs to outputs
often measured as multiple of input/output line rate
N inputs: switching rate N times line rate desirable
three types of switching fabrics
memory
input output
port memory port
(e.g., (e.g.,
Ethernet) Ethernet)
system bus
buffering required when datagrams arrive from fabric faster than the
transmission rate
scheduling discipline chooses among queued datagrams for transmission
Datagram (packets) can be lost
due to congestion, lack of buffers
Priority scheduling – who gets best
performance, network neutrality
Network Layer 4-20
Output port queueing
switch
switch
fabric
fabric
• buffering when arrival rate via switch exceeds output line speed
• queueing (delay) and loss due to output port buffer overflow!
switch switch
fabric fabric
…
– different link types, in: one large datagram
different MTUs out: 3 smaller datagrams
• large IP datagram divided
(“fragmented”) within net
– one datagram becomes reassembly
several datagrams
– “reassembled” only at
final destination …
– IP header bits used to
identify, order related
fragments