KEMBAR78
Network Layer Insights for AI&ML | PDF | Routing | Computer Network
0% found this document useful (0 votes)
56 views61 pages

Network Layer Insights for AI&ML

The document discusses network layer design and protocols. It describes challenges like end-to-end transmission and addressing different networks. It also explains store-and-forward packet switching and the services provided to the transport layer like uniform numbering. Finally, it compares connection-oriented and connectionless implementations and their advantages and disadvantages.

Uploaded by

Disha Girish
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
56 views61 pages

Network Layer Insights for AI&ML

The document discusses network layer design and protocols. It describes challenges like end-to-end transmission and addressing different networks. It also explains store-and-forward packet switching and the services provided to the transport layer like uniform numbering. Finally, it compares connection-oriented and connectionless implementations and their advantages and disadvantages.

Uploaded by

Disha Girish
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 61

Module 3 The Network Layer

THE NETWORK LAYER

The network layer is responsible for end-to-end transmission, requiring knowledge of the network's
topology and selecting appropriate paths to avoid overloading communication lines and routers. It
must also address new problems when the source and destination are in different networks,
primarily using the Internet and its network layer protocol, IP. This chapter will study these issues
and illustrate them using the Internet.
5.1 NETWORK LAYER DESIGN ISSUES

• The text introduces network layer designers' challenges, including the transport layer's service and
the network's internal design.

5.1.1 Store-and-Forward Packet Switching

• The network layer protocols operate in a context of ISP's equipment and customers' equipment. Host
H1 is connected to ISP routers, A, while H2 is on LAN with leased router F, owned by the
customer. These routers are considered part of the ISP network as they run the same algorithms as
the ISP's routers. This context can be seen in Fig. 5-1.

Figure 5-1. The environment of the network layer protocols.

• The equipment uses store-and-forward packet switching, where a host sends a packet to the nearest
router, which stores it until it's processed and verified by the link, then forwards it to the destination
host.

Prof. Soniya R, Dept of AI&ML 1


Module 3 The Network Layer
5.1.2 Services Provided to the Transport Layer
The network layer provides services to the transport layer at the interface, and the services must be
designed with specific goals in mind.
1. The services should be independent of the router technology.

2. The transport layer should be shielded from the number, type, and topology of the routers
present.

3. The network addresses made available to the transport layer should use a uniform numbering
plan, even across LANs and WANs.

• The network layer designers have significant freedom in creating detailed specifications for services
offered to the transport layer. However, this freedom often leads to a debate between two factions:
one, represented by the Internet community, who believes routers' job is to move packets and
nothing else, and the other, represented by telephone companies, who believe the network should
provide a reliable, connection-oriented service. This viewpoint is based on the end-to-end argument,
which has been influential in shaping the Internet.
• The debate continues, with early data networks being connection-oriented, but connectionless
network layers have gained popularity since the early Internet days. The IP protocol is now a
symbol of success, while connection-oriented technologies like ATM are now found in niche uses.
However, the Internet is evolving connection-oriented features as quality of service becomes more
important. Two examples of connection-oriented technologies are MPLS (MultiProtocol Label
Switching) and VLANs, both widely used. The debate continues to evolve as the Internet evolves in
response to the evolving needs of its users.
5.1.3 Implementation of Connectionless Service
• The network layer provides two types of service: connection less and connection-oriented.
Connectionless service injects packets into the network individually and routes them independently,
forming datagram networks. No advance setup is needed, and the network is called a datagram
network.

• On the other hand, connection-oriented service establishes a path from the source router to the
destination router, forming a virtual circuit (VC) network. In a datagram network, a process P1 sends
a long message to a transport layer, which prepares a transport header and sends the result to the

Prof. Soniya R, Dept of AI&ML 2


Module 3 The Network Layer
network layer. This layer operates within the operating system, similar to the physical circuits set up by
telephone systems.

Figure 5-2. Routing within a datagram network.


• In this example, a message is four times longer than its maximum packet size, so the
network layer breaks it into four packets, 1, 2, 3, and 4, and sends each to router A using a
point-to-point protocol like PPP. The ISP takes over, and every router has an internal table
indicating where to send packets for each possible destination. Each table entry is a pair
consisting of a destination and the outgoing line to use for that destination.
• A router has only two outgoing lines, so every incoming packet must be sent to one of
these routers, even if the ultimate destination is to some other router. The router's initial
routing table shows that packets 1, 2, and 3 are stored briefly at A, and each packet is

forwarded according to A's table to C within a new frame. Packet 1 is then forwarded to E
and then to F, and when it gets to F, it is sent within a frame over the LAN to H2.

• However, packet 4 is sent to router B, even though it is also destined for F. A decided to
send packet 4 via a different route than the first three packets, possibly due to a traffic jam
along the ACE path. The routing algorithm manages the tables and makes routing
decisions, and there are several different kinds of routing algorithms.

Prof. Soniya R, Dept of AI&ML 3


Module 3 The Network Layer

5.1.4 Implementation of Connection-Oriented Service


• A connection-oriented service uses a virtual-circuit network to avoid choosing a new route for
every packet sent. A route is chosen during connection setup and stored in router tables. This
route is used for all traffic flowing over the connection, similar to a telephone system. Each
packet carries an identification indicating its virtual circuit. For example, a packet with
connection identifier 1 is sent to router C and E.

• If H3 wants to establish a connection to H2, it chooses connection identifier 1 as its only


connection and tells the network to establish the virtual circuit. This leads to a conflict in the
tables, as A cannot distinguish connection 1 packets from H1 from connection 1 packets from H3.
To avoid conflicts, routers need the ability to replace connection identifiers in outgoing packets.
This process is called label switching and is used within ISP networks in the Internet.

• An example of a connection-oriented network service is MPLS (MultiProtocol Label Switching),


which is used within ISP networks in the Internet with IP packets wrapped in an MPLS header
with a 20-bit connection identifier or label. MPLS is often hidden from customers, but is

increasingly used to help with quality of service and other ISP traffic management tasks.

5.1.5 Comparison of Virtual-Circuit and Datagram Networks


Both virtual circuits and datagrams have their supporters and their detractors. We will now
attempt to summarize both sets of arguments. The major issues are listed in Fig. 5-4, although
purists could probably find a counterexample for everything in the figure.

Prof. Soniya R, Dept of AI&ML 4


Module 3 The Network Layer

Issue Datagram network Virtual-circuit network

Circuit setup Not needed Required

Each packet contains the full source Each packet contains a short VC
Addressing
and destination address number

State Routers do not hold state Each VC requires router table


information information about connections space per connection

Each packet is routed Route chosen when VC is set up;


Routing
independently all packets follow it

Effect of router None, except for packets lost during All VCs that passed through the failed
failures the crash router are terminated

Easy if enough resources can be


Quality of service
Difficult allocated in advance for each VC

Easy if enough resources can be


Congestion control
Difficult allocated in advance for each VC

• Virtual circuits and datagrams have different advantages and disadvantages within a network.
One trade-off is setup time, which takes time and resources, but is easily done with a data
packet in a virtual-circuit network. In contrast, a datagram network requires more
complicated lookup procedures to locate the entry for the destination.
• Datagram networks use longer destination addresses than virtual-circuit networks due to their
global meaning, which can be a significant overhead and waste of bandwidth. Additionally,
datagram networks require more table space in router memory, as each virtual circuit needs
an entry.

Prof. Soniya R, Dept of AI&ML 5


Module 3 The Network Layer
• Virtual circuits offer some advantages in guaranteeing quality of service and avoiding
congestion within the network, as resources can be reserved in advance when the connection
is established. However, congestion avoidance is more difficult with a datagram network.
• For transaction processing systems, the overhead required to set up and clear a virtual circuit
may dwarf its use. However, for long-running uses like VPN traffic between corporate
offices, permanent virtual circuits may be useful.
• Virtual circuits also have a vulnerability problem, as if a router crashes and loses its memory,
all virtual circuits passing through it must be aborted. Datagrams, on the other hand, allow
routers to balance traffic throughout the network, as routes can be changed partway through
long sequence of packet transmissions.

5.2 ROUTING ALGORITHMS

The network layer primarily handles packet routing from source to destination, with most
networks requiring multiple hops. Network layer design focuses on the algorithms and
data structures used to choose routes and manage network segments.

• The network layer is responsible for routing packets from the source machine to the
destination machine, with most networks requiring multiple hops.
• The routing algorithm is a crucial part of network layer design, responsible for
deciding which output line an incoming packet should be transmitted on. If the
network uses
datagrams internally, routing decisions must be made anew for every arriving data
packet, while virtual circuits use established routes for entire sessions.
• A router has two processes: forwarding, which handles packets upon arrival, and
updating the routing tables, where the routing algorithm plays a crucial role in
deciding which routes
to use.
• A routing algorithm should have certain desirable properties: correctness, simplicity,
robustness, stability, fairness, and efficiency. Robustness is crucial for a network to
cope with changes in topology and traffic without requiring all jobs to be aborted.
Stability is
also important, as a stable algorithm reaches equilibrium and stays there, ensuring
communication is not disrupted until the algorithm reaches equilibrium. This is
especially important for major networks that may run continuously for years without

Prof. Soniya R, Dept of AI&ML 6


Module 3 The Network Layer
system-wide failures.
• Fairness and efficiency are often contradictory goals, as seen in Fig. 5-5. To
maximize total flow, X to X′ traffic should be shut off, but X and X′ may
not agree, requiring a
compromise between global efficiency and fairness.
• Optimizing fairness and efficiency requires balancing packet delay and network
throughput, often compromising by reducing packet distance or hops to improve
delay and overall network throughput.

Fig: Network with a conflict between fairness and efficiency

• Static routing is a method where the choice of route is computed in advance, offline,
and downloaded to routers during network booting, allowing for clear routing choices,
such as sending packets to router E regardless of the final destination.
• Adaptive algorithms adapt their routing decisions to changes in topology and traffic.
They differ in information source, route change frequency, and optimization metrics. These
algorithms cover delivery models and can send packets to multiple, all, or one of a set of
destinations. Decisions based on topology are deferred to Sec 5.3

Prof. Soniya R, Dept of AI&ML 7


Module 3 The Network Layer

5.2.1 The Optimality Principle


• The optimality principle, as proposed by Bellman (1957), states that if router J is on the
optimal path from router I to router K, the optimal path from J to K also follows the same
route. This principle can be applied to specific algorithms without considering network
topology or traffic.

• The optimality principle enables the creation of a sink tree, a tree rooted at the destination,
where all optimal routes from all sources are used by all router.

• A sink tree is not unique, but if all possible paths are chosen, it forms a DAG (Directed
Acyclic Graph) with no loops. Sink trees are used for both cases, depending on the
assumption that paths do not interfere, such as a traffic jam on one path not causing
another to divert.
• A sink tree is not unique, but if all possible paths are chosen, it forms a DAG (Directed
Acyclic Graph) with no loops. Sink trees are used for both cases, depending on the
assumption that paths do not interfere, such as a traffic jam on one path not causing
another to divert.
5.2.2 Shortest Path Algorithm
• The study of routing algorithms begins with a straightforward method for computing

Prof. Soniya R, Dept of AI&ML 8


Module 3 The Network Layer
optimal paths based on a complete network picture, despite the fact that not all routers may
have all network details.The idea is to build a graph of the network, with each node of the
graph representing a router and each edge of the graph representing a communication line,
or link. To choose a route between a given pair of routers, the algorithm just finds the
shortest path between them on the graph.

• The concept of a shortest path deserves some explanation. One way of measuring path
length is the number of hops. Using this metric, the paths ABC and ABE in Fig. 5-7 are

equally long. Another metric is the geographic distance in kilometers, in which case ABC
is clearly much longer than ABE (assuming the figure is drawn to scale).
• Dijkstra's algorithm, developed in 1959, finds the shortest paths between a source and all
destinations in a network. Each node is labeled with its distance from the source node
along the best known path, which must be non-negative. Initially, no paths are known, so
all nodes are labeled with infinity. As paths are found, labels may change to reflect better
paths, and labels can be tentative or permanent.
• The labeling algorithm is a method used to find the shortest path from a node A to a node

Prof. Soniya R, Dept of AI&ML 9


Module 3 The Network Layer
D in a network. It starts by marking node A as permanent and then examines all nodes
adjacent to it, relabeling them with distance to A.
• The node with the smallest label is made the new working node. Next, all nodes adjacent
to B are examined. If the sum of the label on B and the distance from B to the node being
considered is less than the label on that node, a shorter path is considered. The entire
graph is searched for the node with the smallest value, making it the working node for the
next round.
• The algorithm consists of six steps. The algorithm works by determining the shortest path

from E to AXYZE, where node Z has already been made permanent. If it has, E has
already been probed, so the AXYZE path cannot be a shorter path. If Z is still tentatively
labeled, if the label is greater than or equal to E, then AXYZE cannot be a shorter path
than ABE. If the label is less than E, Z becomes permanent first, allowing E to be probed
from Z.

• The algorithm is given in Fig. 5-8, where global variables n and dist describe the
graph and are initialized before shortest path is called. The shortest paths from t to s in an
undirected graph are the same as the shortest paths from s to t.

Prof. Soniya R, Dept of AI&ML 10


Module 3 The Network Layer

Prof. Soniya R, Dept of AI&ML 11


Module 3 The Network Layer

5.2.3 Flooding
• Routers in routing algorithms rely on local knowledge rather than the entire network. A
common technique is flooding, where every incoming packet is sent on every outgoing
line except the one it arrived on. This generates numerous duplicate packets, unless
measures are taken. One measure is having a hop counter in each packet header, which is
decremented at each hop and discarded when it reaches zero. The hop counter should be
initialized to the path length.
• Flooding with a hop count can lead to an exponential number of duplicate packets. To
prevent this, routers should track which packets have been flooded and avoid sending
them out again. This can be achieved by placing a sequence number in each packet
received from its hosts, and having a list per source router detailing which sequence
numbers have been seen.

• To prevent list growth without bound, each list should be augmented by a counter, k,
ensuring all sequence numbers through k have been seen. When a packet arrives, it can be
checked if it has been flooded and discarded.
• Flooding ensures packets are delivered to every node in the network, which is effective for
broadcasting information. In wireless networks, all messages transmitted by a station can
be received by all other stations within its radio range, which some algorithms utilize.

• Flooding is a robust routing algorithm that can find a path for a packet even in a war zone,
and requires minimal setup. It can be used as a building block for more efficient routing
algorithms and as a metric for comparison. Flooding always chooses the shortest path,
making it the only algorithm that can produce a shorter delay, excluding the overhead
generated by the flooding process itself.
5.2.4 Distance Vector Routing
• Computer networks utilize dynamic routing algorithms, such as distance vector routing
and link state routing, which are more complex but more efficient in finding the shortest
paths for the current topology, with a focus on the former algorithm.
• A distance vector routing algorithm operates by having each router maintain a table (i.e., a
vector) giving the best known distance to each destination and which link to use to get
Prof. Soniya R, Dept of AI&ML 12
Module 3 The Network Layer
there. These tables are updated by exchanging information with the neighbors. Eventually,
every router knows the best link to reach each destination.
• The distance vector routing algorithm, also known as the Bellman-Ford routing algorithm,
was the original ARPANET routing algorithm and was used in the Internet under the name
RIP. It involves each router maintaining a routing table with an entry for each router,
including the preferred outgoing line and distance estimate, which can be measured as
hops or other metrics.
• The router is assumed to know the distance to its neighbors, either as hops or propagation
delay. If the metric is hops, the distance is one hop.
• If the metric is propagation delay, the router can measure it directly with special ECHO
packets. For example, if delay is used as a metric, the router sends a list of estimated
delays to each neighbor every T msec. If the router knows the delay to X is m msec, it can
reach router i via X in Xi + m msec. The router calculates the best estimate for each
neighbor and uses it in its new routing table.
• This updating process is illustrated in Fig. 5-9. Part (a) shows a network. The first four
columns of part (b) show the delay vectors received from the neighbors of router J. A
claims to have a 12-msec delay to B, a 25-msec delay to C, a 40- msec delay to D, etc.
Suppose that J has measured or estimated its delay to its neighbors, A, I, H, and K, as 8,
10, 12, and 6 msec, respectively.

Prof. Soniya R, Dept of AI&ML 13


Module 3 The Network Layer
• Consider how J computes its new route to router G. It knows that it can get to A in 8 msec,
and furthermore A claims to be able to get to G in 18 msec, so J knows it can count on a
delay of 26 msec to G if it forwards packets bound for G to A. Similarly, it computes the
delay to G via I, H, and K as 41 (31 + 10), 18 (6 + 12), and 37 (31 + 6) msec, respectively.
The best of these values is 18, so it makes an entry in its routing table that the delay to G is
18 msec and that the route to use is via H. The same calculation is performed for all the
other destinations, with the new routing table shown in the last column of the figure.

5.2.5 Link State Routing

• Distance vector routing was used in the ARPANET until 1979, when it was replaced by
link state routing. The primary problem that caused its demise was that the algorithm often
took too long to converge after the network topology changed (due to the count-to-infinity
problem). Consequently, it was replaced by an entirely new algorithm, now called link
state routing. Variants of link state routing called IS-IS and OSPF are the routing
algorithms that are most widely used inside large networks and the Internet today.
• The idea behind link state routing is fairly simple and can be stated as five parts. Each
router must do the following things to make it work:
1. Discover its neighbors and learn their network addresses.
2. Set the distance or cost metric to each of its neighbors.
3. Construct a packet telling all it has just learned.
4. Send this packet to and receive packets from all other routers.
5. Compute the shortest path to every other router.
• In effect, the complete topology is distributed to every router. Then Dijkstra’s algorithm
can be run at each router to find the shortest path to every other router. Below we will
consider each of these five steps in more detail
Learning about the Neighbors
• A router learns its neighbors by sending a special HELLO packet on each point-to-point

line, and the router on the other end sends a reply with its name.

Prof. Soniya R, Dept of AI&ML 14


Module 3 The Network Layer
• These names must be globally unique to determine if all three routers are connected to
the same F. When connected by a broadcast link, the situation becomes more
complicated, as shown in a broadcast LAN with three routers connected to one or more additional
routers.

Prof. Soniya R, Dept of AI&ML 15


Module 3 The Network Layer

• The broadcast LAN provides connectivity between each pair of attached routers.
However, modeling the LAN as many point-to-point links increases the size of the
topology and leads to wasteful messages. A better way to model the LAN is to consider
it as a node itself, as shown in Fig. 5-11(b). Here, we have introduced a new, artificial
node, N, to which A, C, and F are connected. One designated router on the LAN is
selected to play the role of N in the routing protocol. The fact that it is possible to go
from A to C on the LAN is represented by the path ANC here.
• Setting Link Costs: The link state routing algorithm requires each link to have a
distance or cost metric for finding shortest paths. The cost to reach neighbors can be set
automatically, or configured by the network operator. A common choice is to make the
cost inversely proportional to the bandwidth of the link. For example, 1-Gbps Ethernet
may have a cost of 1 and 100-Mbps Ethernet a cost of 10. This makes higher-capacity
paths better choices. If the network is geographically spread out, the delay of the links
may be factored into the cost so that paths over shorter links are better choices. The most
direct way to determine this delay is to send over the line a special ECHO packet that the
other side is required to send back immediately. By measuring the round-trip time and
dividing it by two, the sending router can get a reasonable estimate of the delay.
• Building Link State Packets: Once the information needed for the exchange has been
collected, the next step is for each router to build a packet containing all the data. The
packet starts with the identity of the sender, followed by a sequence number and age (to
be described later) and a list of neighbors. The cost to each neighbor is also given. An
example network is presented in Fig. 5-12(a) with costs shown as labels on the lines. The
corresponding link state packets for all six routers are shown in Fig. 5- 12(b).
• Building the link state packets is easy. The hard part is determining when to build them.
One possibility is to build them periodically, that is, at regular intervals. Another
possibility is to build them when some significant event occurs, such as a line or
neighbor going down or coming back up again or changing its properties appreciably.
5.2.6 Hierarchical Routing
• As networks grow, router routing tables grow proportionally, consuming more memory,
CPU time, and bandwidth. When the network becomes too large for every router to have
Prof. Soniya R, Dept of AI&ML 16
Module 3 The Network Layer
an entry for every other router, hierarchical routing is used.
• Routers are divided into regions, each knowing how to route packets within its own
region but not about the internal structure of other regions. This allows interconnected
networks to treat each region as a separate area, allowing routers to avoid knowing the
topological structure of other networks.
• For large networks, a two-level hierarchy may not be sufficient, as it may be necessary
to group regions into clusters, clusters into zones, and zones into groups. For example, a
packet from Berkeley to Malindi would be routed through a multilevel hierarchy.
• The Berkeley router would know the topology within California but send all out-of-state
traffic to the Los Angeles router. The Los Angeles router could route traffic directly to
other domestic routers but send all foreign traffic to New York. The New York router
would direct all traffic to the destination country responsible for handling foreign traffic,
such as Nairobi.
• The packet would then work its way down the tree in Kenya until it reached Malindi.
Hierarchical routing reduces the table from 17 to 7 entries, but it also increases path
length. For example, the best route from 1A to 5C is via region 2, but all traffic to region
5 goes via region 3, as it is better for most destinations in region 5.

Prof. Soniya R, Dept of AI&ML 17


Module 3 The Network Layer
`

5.2.7 Broadcast Routing


• Broadcasting is the process of sending a packet to all destinations simultaneously, such
as weather reports or stock market updates.
• This method requires no network features and requires a complete list of all destinations.
However, this method is wasteful, slow, and requires a complete list of all hosts, making
it not desirable in practice despite its widespread application.
• Multidestination routing is an improvement in network communication where each
packet contains a list of destinations or a bit map indicating the desired destinations.
When a packet arrives at a router, it checks all the destinations to determine the set of
output lines needed.
• The router generates a new copy of the packet for each output line and includes only
those destinations that will use the line. This partitions the destination set among the
output lines, resulting in more efficient network bandwidth usage. However, this scheme
still requires the source to know all destinations and requires router work.
• Flooding is a better broadcast routing technique that efficiently uses links with a simple
decision rule at routers. Although it is not suitable for point-to-point communication, it is
worth considering for broadcasting.
• Reverse path forwarding is an elegant and simple idea that checks if a broadcast packet
arrived on the link normally used for sending packets toward the source. If so, the router
forwards copies of the packet onto all links except the one it arrived on. If the packet
arrived on a different link, it is discarded as a likely duplicate.

Prof. Soniya R, Dept of AI&ML 18


Module 3 The Network Layer

• Reverse path forwarding is a network routing algorithm where router I sends packets to
previously unvisited routes on the first hop. The second hop generates eight packets,
two by each router that received a packet on the first hop.
• All eight packets arrive at previously unvisited routes, with five along the preferred
line. The third hop generates six packets, with only three arriving on the preferred path.
After five hops and 24 packets, broadcasting terminates, compared to four hops and 14
packets if the sink tree was followed exactly. Reverse path forwarding is efficient and
easy to implement, sending the broadcast packet over each link only once in each
direction, similar to flooding, without the need for routers to remember sequence
numbers or list all destinations in the packet.
• The final broadcast algorithm enhances reverse path forwarding by using a sink tree or
other spanning tree for router initiating the broadcast.

• A spanning tree is a subset of the network that includes all routers but has no loops. If
each router knows which line belongs to the tree, it can copy an incoming broadcast
packet onto all spanning tree lines except the one it arrived on.
• This method efficiently uses bandwidth, generating the minimum number of packets
needed. However, each router must have knowledge of a spanning tree for the method to
be applicable.
5.2.8 Multicast Routing
• Multicasting is a method used to send messages to large but small groups in a network.
This is particularly useful for applications like multiplayer games or live sports events.
Sending a distinct packet to each receiver is expensive unless the group is small.
• However, broadcasting a packet is wasteful if the group consists of numerous machines
on a million-node network. Multicasting requires a routing algorithm to create and
destroy groups and identify routers as members. Each group is identified by a multicast
address, and routers know their group membership.
• Multicast routing schemes use spanning trees to deliver packets to members of a group
efficiently, based on the group's density or sparsity. Broadcast is a good start for dense
groups, as it efficiently gets the packet to all parts of the network. However, it may reach
routers not members of the group, which is wasteful. Deering and Cheriton (1990)

19
Module 3 The Network Layer
proposed pruning the broadcast spanning tree by removing links that do not lead to
members, resulting in an efficient multicast spanning tree.
• For example, consider two groups, 1 and 2, with routers attached to hosts belonging to
one or both groups. A spanning tree for the leftmost router can be used for broadcast but
is overkill for multicast. A multicast spanning tree for the leftmost router sends packets
only along this tree, which is more efficient than the broadcast tree due to the number of
links. Different multicast groups have different spanning trees.
• The spanning tree can be pruned using link state routing, where each router is aware of
the complete topology and can construct its own pruned tree for each sender to the group.
This is an example of a link state protocol called MOSPF (Multicast OSPF).
• Distance vector routing follows a different pruning strategy, with the basic algorithm
being reverse path forwarding. When a router receives a multicast message for a
particular group, it responds with a PRUNE message, preventing the neighbor from
sending more multicasts. This recursive pruning of the spanning tree is also possible for routers
with no group members among their hosts. DVMRP (Distance Vector Multicast Routing Protocol)
is an example of this method.

20
Module 3 The Network Layer

• Core-based trees are an alternative design for group routing, where routers agree on a
root (core or rendezvous point) and build the tree by sending packets from each member
to the root. The tree is the union of the paths traced by these packets. For group 1, a
sender sends a packet to the core, which is forwarded down the tree. This performance
optimization allows packets to be multicast without reaching the core before being
forwarded up or down all branches.
• Shared trees are not optimal for all sources, as they can be inefficient depending on the
location of the core and senders. However, they can be a significant savings in storage
costs, messages sent, and computation. Each router maintains one tree per group,
reducing the need for multiple trees. Additionally, routers not part of the tree do not
support the group. This is why core-based trees are used for multicasting to sparse
groups in the Internet, as part of popular protocols like PIM

5.2.9 Anycast Routing


• Delivery models such as unicast, broadcast, and multicast are used to send packets to
specific destinations. Anycast, a variant, delivers a packet to the nearest member of a
group. Anycast routing schemes find these paths.
• This is useful when nodes provide services like time of day or content distribution, where
the right information is received regardless of the contact node. Anycast is used in the
21
Module 3 The Network Layer
Internet as part of DNS. Regular distance vector and link state routing can produce
anycast routes.

• The distance vector routing procedure is used to assign addresses to group 1 members,
resulting in nodes sending to the nearest instance of destination 1. This is because the
routing protocol doesn't recognize multiple instances of destination 1, believing all
instances of node 1 are the same.
5.2.10 Routing for Mobile Hosts
• Millions of people use computers on the go, with mobile hosts being either stationary or
mobile. As people increasingly want to stay connected, networks must find mobile
hosts to route packets.
• In a model where all hosts have a permanent home location and permanent home
address, the routing goal is to send packets to mobile hosts using their fixed home
addresses and efficiently reach them wherever they may be. The challenge is to find
mobile hosts to ensure efficient communication and reach them efficiently.
• A different model for mobile network routing could involve recompiling routes as
mobile hosts move and topology changes. This would reduce the burden of constantly
computing new routes. Using home addresses can also help reduce this burden. Another
option is to provide mobility above the network layer, as laptops acquire new network
addresses when moved to new locations.
• This model allows a laptop to browse the web but requires a higher layer location
service for other hosts to send packets. Connections cannot be maintained while the
host is moving, so network-layer mobility is useful.
• Mobile routing in the Internet and cellular networks involves the mobile host indicating
its current location to a home agent, who forwards packets to the mobile host's home
22
Module 3 The Network Layer
location. This process is crucial for ensuring efficient communication and delivery of
data. In a scenario where the mobile host is temporarily in San Diego, the home agent

acquires a local network address, known as a care of address.

The mobile host sends a registration message to the home agent, which is a control
message, not a data message. The sender then sends a data packet to the mobile host using
its permanent address, which is routed by the network to the host's home location. In New
York, the home agent intercepts the packet, wraps it with a new header, and sends
the bundle to the care of address. This tunneling mechanism is crucial in the Internet
and cellular networks.

23
Module 3 The Network Layer

• The mobile routing system involves a triangle routing, where the mobile host retrieves
the packet from the sender and sends its reply packet directly to the sender. This route
may be circuitous if the remote location is far from the home location.
• The sender may learn the current care of address during step 4. Subsequent packets can
be routed directly to the mobile host by tunneling them to the care of address, bypassing
the home location entirely. If connectivity is lost, the home address can always be used to
reach the mobile.
• Security is an important aspect, as messages may contain security information to check
with cryptographic protocols. The scheme is modeled on IPv6 mobility, which is used in
the Internet and IP-based cellular networks like UMTS. Extensions of the basic scheme
support mobile networks without host work.

5.2.11 Routing in Ad Hoc Networks


• We have now seen how to do routing when the hosts are mobile but the routers are fixed. An
even more extreme case is one in which the routers themselves are mobile. Among the
possibilities are emergency workers at an earthquake site, military vehicles on a battlefield, a
fleet of ships at sea, or a gathering of people with laptop computers in an area lacking 802.11
• In all these cases, and others, each node communicates wirelessly and acts as both a host and a
router. Networks of nodes that just happen to be near each other are called ad hoc networks or
MANETs (Mobile Ad hoc NETworks). Let us now examine them briefly. More information can
be found in Perkins (2001).
• What makes ad hoc networks different from wired networks is that the topology is suddenly
tossed out the window. Nodes can come and go or appear in new places at the drop of a bit. With
a wired network, if a router has a valid path to some destination, that path continues to be valid
barring failures, which are hopefully rare. With an ad hoc network, the topology may be
changing all the time, so the desirability and even the validity of paths can change spontaneously
without warning. Needless to say, these circumstances make routing in ad hoc networks more
challenging than routing in their fixed counterparts.

24
Module 3 The Network Layer
• Numerous routing algorithms for ad hoc networks have been proposed, but their practical use is
limited compared to mobile networks. One popular algorithm is AODV (Ad hoc On-demand
Distance Vector), adapted for mobile environments with limited bandwidth

and battery lifetimes. It discovers and maintains routes, highlighting its potential in ad hoc
networks.

• Route Discovery : The Ad Hoc Network (AODV) is a network algorithm that discovers routes
to a destination on demand, saving time and effort when the topology changes
before the route is used. The topology of an ad hoc network can be described by a graph
of connected nodes, with two nodes connected if they can communicate directly using
their radios. For simplicity, all connections are symmetric.

• The algorithm is based on a newly formed ad hoc network, where a process at node A
sends a packet to node I. The algorithm maintains a distance vector table at each node,
keyed by destination, providing information about the destination and its neighbors. If no
entry is found for node I, the process must discover a route to it. This "on demand"
approach makes the algorithm efficient and efficient.

25
Module 3 The Network Layer

• A sends a ROUTE REQUEST packet to I, which is broadcasted using flooding. The packet is
then rebroadcast to nodes F, G, C, H, E, and I. A sequence number is set at the source to
remove duplicates during the flood.
• The request reaches node I, which constructs a ROUTE REPLY packet. This packet is
unicast along the reverse of the path followed by the request. Intermediate nodes must
remember the node that sent the request and increment a hop count as they forward the reply.
The replies indicate which neighbor to use to reach the destination. Intermediate nodes G and
D input the best route they hear into their routing tables. When the reply reaches A, a new
route, ADGI, is created.
• The algorithm generates numerous broadcasts in large networks, even for nearby destinations.
To reduce overhead, the scope of broadcasts is limited using the IP packet's Time to live field.
If the field is 0, the packet is discarded. The route discovery process is modified by
broadcasting a ROUTE REQUEST packet with a Time to live set to 1, and then sending more
packets in increasingly wider rings, starting locally and then globally.
• Route Maintenance : The topology of a network can change spontaneously due to nodes
moving or being switched off. The algorithm must handle this by broadcasting a Hello
message to its neighbors, which is expected to respond. If no response is received, the

broadcaster knows that the neighbor has moved out of range or failed, and if a packet is sent to
a non-responsive neighbor, it learns that the neighbor is no longer available.

26
Module 3 The Network Layer

• This information is used to purge routes that no longer work. Each node, N, tracks its
active neighbors who have sent a packet for a possible destination during the last ΔT seconds.
When any of N's neighbors becomes unreachable, it checks its routing table to see which
routes have routes using the now-gone neighbor. The active neighbors inform each other
recursively until all routes depending on the now-gone node are purged from all routing tables.
• Invalid routes are removed from the network, and senders can find new valid ones using the
discovery mechanism. However, distance vector protocols can suffer from slow convergence
or count-to-infinity problems after topology changes. To ensure rapid convergence, routes
include a sequence number controlled by the destination, which increments every time a fresh
ROUTE REPLY is sent. Senders request a fresh route by including the destination sequence
number of the last used route in the ROUTE REQUEST.
• Intermediate nodes store routes with a higher sequence number or the few hops for the
current sequence number. This on-demand protocol saves bandwidth and battery life compared
to a standard distance vector protocol that broadcasts updates periodically.
• The text discusses ad hoc routing schemes, such as DSR (Dynamic Source Routing) and GPSR
(Greedy Perimeter Stateless Routing). These schemes share route discovery and maintenance
when routes overlap, allowing for resource savings. For example, if B wants to send packets to
I, it will perform route discovery first, then reach D, which already has a route to I. The choice
of protocol depends on the types of ad hoc networks that prove useful in practice.

27
Module 3 The Network Layer

5.3 Congestion Control Algorithms

● Too many packets present in (a part of) the network causes packet delay and loss that degrades
performance. This situation is called congestion.
● The network and transport layers share responsibility for handling congestion. The network layer
directly experiences congestion and must decide on handling excess packets.
● The most effective way to control congestion is to reduce the load placed by the transport layer on
the network, requiring collaboration between the two layers.

Figure 3.1. With too much traffic, performance drops sharply.

● The above figure depicts the onset of congestion, The network's carrying capacity is maintained
when the number of packets sent is within its limits. If twice as many packets are sent, twice as
many are delivered.
● However, as traffic loads approach the capacity, some packets are lost, consuming some of the
capacity, causing the number of delivered packets to fall below the ideal curve, resulting in
congested networks.
● A poorly designed network can experience congestion collapse, where performance decreases as
load increases beyond capacity. This occurs when packets are delayed, making them no longer
useful when they leave the network.
● In the early internet, packets spent waiting for backlogs could reach their maximum time. Senders
re-transmitted delayed packets, wasting capacity. To capture these factors, the y-axis of Fig. 3.1 is

28
Module 3 The Network Layer
given as goodput, which is the rate at which useful packets are delivered by the network.

● Congestion is a common issue in networks, causing queues and packet loss. Adding more memory
can help, but it can worsen congestion as packets time out and duplicates are sent. Low-bandwidth
links or routers that process packets slowly can also become congested.
● To improve congestion, traffic can be directed away from the bottleneck, but eventually, all regions
will be congested, necessitating the need for faster network design.

● Congestion control and flow control are two distinct concepts in network management.
Congestion control ensures the network can handle the offered traffic, involving all hosts and
routers' behavior. Flow control focuses on the traffic between a sender and a receiver, ensuring a fast
sender cannot transmit data faster than the receiver can absorb it.
● Congestion control is often confused with flow control, as the best way to handle both problems is
to get the host to slow down. Understanding congestion control involves examining approaches at
different time scales, preventing congestion, and coping with it once it has set in.

5.3.1 Approaches to Congestion Control

1. The presence of congestion means that the load is (temporarily) greater than the resources (in a part
of the network) can handle. Two solutions come to mind: increase the resources or decrease the
load. As shown in Fig. 5-22, these solutions are usually applied on different time scales to either
prevent congestion or react to it once it has occurred.

Figure 3.2. Timescales of approaches to congestion control.

2. To avoid congestion, build a network that matches the traffic it carries. Resources can be added
dynamically during congestion, such as using spare routers or enabling lines.

3. Provisioning involves upgrading heavily utilized links and routers at the earliest opportunity. Routes

29
Module 3 The Network Layer
can be tailored to changing traffic patterns, such as shifting traffic away from heavily used paths.

4. Traffic-aware routing allows mobile listeners to route packets around hotspots, Some local radio
stations have helicopters flying around their cities to report on road congestion to make it possible
for their mobile listeners to route their packets (cars) around hotspots. This is called traffic-aware
routing. and splitting traffic across multiple paths is helpful.

5. However, sometimes it is not possible to increase capacity. The only way then to beat back the
congestion is to decrease the load. In a virtual-circuit network, new connections can be refused if
they would cause the network to become congested. This is called admission control.

6. At a fine level, when congestion is imminent the network can request traffic sources causing the
problem to throttle their traffic to reduce congestion. To identify onset of congestion, routers can
monitor average load, queuing delay or packet loss. Rising numbers indicate growing congestion.

7. To control sources, routers must participate in a feedback loop. The timescale needs careful
adjustment:
(a) If feedback is too frequent, the system will oscillate wildly.
(b) If feedback is too slow, congestion control will react sluggishly.

8. Sending feedback messages during congestion adds more network load. When all else fails, network
has to discard packets it cannot deliver, which is called load shedding. Good packet discard policies
can help prevent congestion collapse.

5.3.2 Traffic-Aware Routing

1. The first approach we will examine is traffic-aware routing. The goal in taking load into account
when computing routes is to shift traffic away from hotspots that will be the first places in the
network to experience congestion.

2. The most direct way to do this is to set the link weight to be a function of the fixed link bandwidth
and propagation delay plus the variable measured load or average queuing delay. Least-weight paths
will then favor paths that are more lightly loaded, all else being equal.

30
Module 3 The Network Layer

3. Traffic-aware routing was used in the early Internet according to this model by Khanna and Zinky in
1989. However, there is a risk. Consider the network of Fig. 3.3, which is divided into two parts,
East and West, connected by two links, CF and EI. Suppose that most of the traffic between East
and West is using link CF, and, as a result, this link is heavily loaded with long delays. Including
queueing delay in the weight used for the shortest path calculation will make EI more attractive.
After the new routing tables have been installed, most of the East-West traffic will now go over EI,
loading this link. Consequently, in the next update, CF will appear to be the shortest path. As a
result, the routing tables may oscillate wildly, leading to erratic routing and many potential problems.

Figure 3.3 A network in which the East and West parts are connected by two links.

4. If load is ignored and only bandwidth and propagation delay are considered, this problem does not
occur. Attempts to include load but change weights within a narrow range only slow down routing
oscillations. Two techniques can contribute to a successful solution. The first is multi path routing,
in which there can be multiple paths from a source to a destination. In our example this means that
the traffic can be spread across both of the East to West links.

5. The second one is for the routing scheme to shift traffic across routes slowly enough that it is able to
converge, as in the scheme of Gallagher (1977). Given these difficulties, in the Internet routing
protocols do not generally adjust their routes depending on the load. Instead, adjustments are made
outside the routing protocol by slowly changing its inputs. This is called Traffic engineering.

31
Module 3 The Network Layer
5.3.3 Admission Control

1. Admission control is a technique used to prevent congestion in virtual circuit networks. The idea is
to not establish a new virtual circuit if it would make the network congested. This is better than
letting more circuits in when the network is already busy.

2. Determining when a new circuit will lead to congestion is the challenge. In telephone networks, it is
straightforward since calls have fixed bandwidth. But in computer networks, virtual circuits have
varying bandwidths.
3. So for admission control to work, the new circuit needs to provide some characterization of its
traffic. Traffic can be described in terms of its rate and shape. But a simple description is difficult
due to its bursty nature.
4. The average rate only tells half the story since traffic is often bursty. Bursty traffic like web traffic
is harder to handle than streaming traffic with the same throughput since web traffic bursts are more
likely to congest routers.
5. A commonly used method to capture this effect is the leaky bucket or token bucket model.
The leaky bucket has two parameters:
(a) The average rate which bounds the long term traffic rate
(b) The burst size which bounds the maximum burst of traffic
6. The network can use traffic descriptions for admission control when deciding whether to admit new
virtual circuits. One option is for the network to reserve enough capacity along circuit paths to
prevent congestion. This guarantees quality of service for users.
7. Even without guarantees, the network can estimate how many circuits will fit within capacity
without congestion using traffic descriptions. For example, 10 circuits at up to 10 Mbps passing
through a 100 Mbps link can be admitted to avoid congestion. But this is wasteful since circuits may
not transmit at full speed at the same time.
8. Measurements of past behavior and statistics can be used to estimate the right number of circuits to
admit, trading better performance for acceptable risk.
9. Admission control can also be combined with traffic-aware routing by considering routes around
traffic hotspots as part of the setup procedure. For example, consider the network illustrated in Fig.
3.4(a), in which two routers are congested, as indicated.

32
Module 3 The Network Layer

Figure 3.4. (a) A congested network. (b) The portion of the network that is not congested. A virtual circuit from A
to B is also shown.

10. Suppose that a host attached to router A wants to set up a connection to a host attached to router B.
Normally, this connection would pass through one of the congested routers. To avoid this situation,
we can redraw the network as shown in Fig. 5-24(b), omitting the congested routers and all of their
lines. The dashed line shows a possible route for the virtual circuit that avoids the congested routers.

5.3.4 Traffic Throttling

Traffic Throttling is an approach used to avoid congestion. In networks and the internet, the
senders try to send as much traffic as possible as the network can readily deliver. In a network
when congestion is approaching it should tell the senders of packets to slow down them. Traffic
Throttling can be used in virtual circuit networks and datagram networks.

Let us now look at some approaches to throttling traffic that can be used in both datagram networks
and virtual-circuit networks. Each approach must solve two problems.

Problem 1- The router must be able to determine when the congestion is approaching. It must
identify the congestion before it has arrived. For this, each router used in the network must

33
Module 3 The Network Layer
continuously check for all the resources and their activities in the network. Router can
continuously monitor using three possibilities. They are:

• Using output links


• To buffer the most useful and priority-based packets inside the router
• The total number of packets that are lost because of insufficient buffering
Problem 2- The second problem is that the router must send the feedback on time to the senders
that are creating congestion. To deliver this feedback, the router must identify the senders
properly. The router needs to send them warning efficiently without sending more packets in an
already congested network. Different feedback mechanisms are used for solving this problem.
Feedback Mechanisms
1. Choke packets
Choke packets are a mechanism where the router directly sends the choked packet back to its
sender or host. The header bit of the original packet is turned on so that it will not be able to
generate any choke packet. At the time of congestion to decrease the load router will send back
only the choked packets at a lower rate. In the case of datagram networks randomly, the packets
are selected therefore it leads to more choked packets. The below diagram describes the choke
packets approach.
2. Explicit Congestion Notification

In the explicit congestion notification approach the router does not send extra packets to the host
but sets a bit of any one of the packet headers to inform that the network has approached with
congestion. When any packet is delivered in the network the destination sends a reply packet to
the sender informing that congestion has occurred. In the case of choke packets, the sender then
throttles its transmission. The below diagram describes the explicit congestion notification.

Fig 3.5: Explicit congestion notification

34
Module 3 The Network Layer

3. Hop-by-Hop Backpressure
After the congestion has been signaled still due to a slow signal many packets are received from
the long distances. The choke packets have an effect at every step and each router requires more
buffers. The main aim of this Hop-by-Hop Backpressure technique is to provide faster relief at the
point of congestion in the network. This technique propagates in the opposite direction of the data
and is majorly used in virtual circuits. The below diagram describes Hop-by-Hop Backpressure in
detail.

Fig 3.6: Hop by Hop Backpressure

5.3.5 Load Shedding

35
Module 3 The Network Layer

1. Load shedding is one of the techniques used for congestion control. A network router
consists of a buffer. This buffer is used to store the packets and then route them to their
destination. Load shedding is defined as an approach of discarding the packets when the
buffer is full according to the strategy implemented in the data link layer. The selection of
packets to discard is an important task. Many times packets with less importance and old
packets are discarded.

2. The term comes from the world of electrical power generation, where it refers to the
practice of utilities intentionally blacking out certain areas to save the entire grid from
collapsing on hot summer days when the demand for electricity greatly exceeds the supply.
3. Selection of Packets to be Discarded: In the process of load shedding the packets need to
be discarded in order to avoid congestion. Therefore which packet needs to be
discarded is a question. Random early detection is one of the approach used to discard
the packets.
Random early detection

4. This situation can be exploited to help reduce congestion. By having routers drop packets
early, before the situation has become hopeless, there is time for the source to take action
before it is too late. A popular algorithm for doing this is called RED (Random Early
Detection)

5. To determine when to start discarding, routers maintain a running average of their queue
lengths. When the average queue length on some link exceeds a threshold, the link is said
to be congested and a small fraction of the packets are dropped at random.
6. Picking packets at random makes it more likely that the fastest senders will see a packet
drop; this is the best option since the router cannot tell which source is causing the most
trouble in a datagram network. The affected sender will notice the loss when there is no
acknowledgement, and then the transport protocol will slow down. The lost packet is thus
delivering the same message as a choke packet, but implicitly, without the router sending
any explicit signal.

7. RED routers improve performance compared to routers that drop packets only when their
buffers are full, though they may require tuning to work well. For example, the ideal
number of packets to drop depends on how many senders need to be notified of congestion.

36
Module 3 The Network Layer
8. However, ECN is the preferred option if it is available. It works in exactly the same
manner, but delivers a congestion signal explicitly rather than as a loss; RED is used when
hosts cannot receive explicit signals.

5.4 QUALITY OF SERVICE

• The techniques we looked at in the previous sections are designed to reduce congestion
and improve network performance.
• Some applications and customers require stronger performance guarantees than what can
be achieved under typical circumstances.

Overprovisioning

• An easy solution for ensuring good quality of service is to build a network with sufficient
capacity to handle any anticipated traffic.
• This approach, known as overprovisioning, allows the network to carry application traffic
with minimal loss and low latency, assuming a decent routing scheme.
• The result is optimal performance, and the telephone system is an example of a somewhat
overprovisioned system, evident in the near-instant dial tone availability.

Drawbacks of Overprovisioning:

• The primary drawback of overprovisioning is its high cost, essentially solving the problem
by investing more resources.
• Quality of service mechanisms offer an alternative by enabling a network with less
capacity to meet application requirements at a lower cost.
• Overprovisioning relies on expected traffic, and significant issues may arise if traffic
patterns change unexpectedly.

Benefits of Quality-of-Service Mechanisms:

• Quality of service mechanisms allow a network with less capacity to effectively meet
application requirements at a lower cost compared to overprovisioning.
• These mechanisms enable the network to uphold performance guarantees even during
traffic spikes, although this may involve rejecting some requests.
• Four issues must be addressed to ensure quality of service:
1. What applications need from the network.

37
Module 3 The Network Layer
2. How to regulate the traffic that enters the network.
3. How to reserve resources at routers to guarantee performance.
4. Whether the network can safely accept more traffic.
5.4.1 Application Requirements
• Definition of Flow:
• A stream of packets moving from a source to a destination is termed a flow (Clark, 1988).
• Flows can encompass all packets in a connection in a connection-oriented network or all
packets sent from one process to another in a connectionless network.
• Characterization of Flow Needs:
• Each flow's requirements can be described by four primary parameters: bandwidth,
delay, jitter, and loss.
• These parameters collectively determine the Quality of Service (QoS) necessary
for the flow.
• Common Applications and Network Requirements:
• Fig. 5-27 lists various common applications and the level of stringency in their
network requirements.

5.5 QUALITY OF SERVICE

• The techniques we looked at in the previous sections are designed to reduce congestion
and improve network performance.
• Some applications and customers require stronger performance guarantees than what can
be achieved under typical circumstances.

Overprovisioning

• An easy solution for ensuring good quality of service is to build a network with sufficient
capacity to handle any anticipated traffic.
• This approach, known as overprovisioning, allows the network to carry application traffic
with minimal loss and low latency, assuming a decent routing scheme.
• The result is optimal performance, and the telephone system is an example of a somewhat
overprovisioned system, evident in the near-instant dial tone availability.

Drawbacks of Overprovisioning:

38
Module 3 The Network Layer
• The primary drawback of overprovisioning is its high cost, essentially solving the problem
by investing more resources.
• Quality of service mechanisms offer an alternative by enabling a network with less
capacity to meet application requirements at a lower cost.
• Overprovisioning relies on expected traffic, and significant issues may arise if traffic
patterns change unexpectedly.

Benefits of Quality-of-Service Mechanisms:

• Quality of service mechanisms allow a network with less capacity to effectively meet
application requirements at a lower cost compared to overprovisioning.
• These mechanisms enable the network to uphold performance guarantees even during
traffic spikes, although this may involve rejecting some requests.
• Four issues must be addressed to ensure quality of service:
1. What applications need from the network.
2. How to regulate the traffic that enters the network.
3. How to reserve resources at routers to guarantee performance.
4. Whether the network can safely accept more traffic.
5.4.2 Application Requirements
• Definition of Flow:
• A stream of packets moving from a source to a destination is termed a flow (Clark, 1988).
• Flows can encompass all packets in a connection in a connection-oriented network or all
packets sent from one process to another in a connectionless network.
• Characterization of Flow Needs:
• Each flow's requirements can be described by four primary parameters: bandwidth,
delay, jitter, and loss.
• These parameters collectively determine the Quality of Service (QoS) necessary
for the flow.
• Common Applications and Network Requirements:
• Fig. 5-27 lists various common applications and the level of stringency in their
network requirements.

• Notably, network requirements are less demanding when an application can


enhance the service provided by the network.

39
Module 3 The Network Layer
• Example Contrasts:
• Networks do not necessarily need to be lossless for reliable file transfer, as some
loss can be rectified with retransmissions.
• Delivery of packets with identical delays is not crucial for audio and video playout,
as some jitter can be smoothed by buffering packets at the receiver.
• Bandwidth Requirements:
• Applications exhibit varying bandwidth needs.
• Email, audio in all forms, and remote login have relatively low bandwidth
requirements.
• File sharing and video in all forms demand a significant amount of bandwidth.
• Delay Sensitivity:
• File transfer applications, including email and video, are not highly sensitive to
delay.
• Interactive applications like Web surfing and remote login are more delay-
sensitive.
• Real-time applications such as telephony and videoconferencing have strict delay
requirements.
• Jitter and its Impact:
• Jitter, the variation in delay or packet arrival times, is crucial.
• Email, audio, and file transfer are generally not sensitive to jitter.
• Remote login may be affected by jitter, causing bursts of updates on the screen.
• Video and audio are extremely sensitive to jitter; even small variations can have a
significant impact.
• Loss Tolerance:
• The first four applications (email, audio, file transfer, and video) have more
stringent loss requirements, requiring all bits to be delivered correctly.
• Retransmissions are typically used to achieve this goal.
• Audio and video applications can tolerate some lost packets without
retransmission, as users may not notice short pauses or occasional skipped frames.
• Network Support for QoS:
• Networks may support different categories of Quality of Service (QoS) to
accommodate various applications.

40
Module 3 The Network Layer
• ATM networks, once part of a grand networking vision, provide an example of
supporting different QoS categories but have become a niche technology.
• Networks may support different categories of QoS.
1. Constant bit rate (e.g., telephony).
2. Real-time variable bit rate (e.g., compressed videoconferencing).
3. Non-real-time variable bit rate (e.g., watching a movie on demand).
4. Available bit rate (e.g., file transfer).
5.4.3 Traffic Shaping

• Traffic Characterization:
• Before a network can make Quality of Service (QoS) guarantees, it needs to know
the nature of the traffic being guaranteed.

• In the telephone network, the characterization is straightforward, such as a voice


call needing 64 kbps with specific sampling intervals.

• Bursty Nature of Data Networks:


• Traffic in data networks is often bursty due to variations in traffic rates (e.g.,
compressed videoconferencing), user interactions (e.g., browsing new web pages),
and task switching by computers.
• Traffic Shaping:
• Traffic shaping is a technique that regulates the average rate and burstiness of data
flow entering the network.
• It allows applications to transmit diverse traffic patterns while providing a simple
and useful way to describe these patterns to the network.
• The customer and provider agree on a traffic pattern (shape) for a flow, often
outlined in a Service Level Agreement (SLA) for long-term commitments.

• SLA and Traffic Monitoring:


• The Service Level Agreement (SLA) outlines the agreed-upon traffic patterns
between the customer and provider.
• Traffic shaping, when adhered to by the customer, helps reduce congestion and

41
Module 3 The Network Layer
ensures the network can fulfill its promises.
• Traffic policing involves monitoring a traffic flow to verify adherence to the
agreement, potentially dropping excess packets or marking them with lower
priority.
• Importance of Shaping and Policing:
• Shaping and policing are critical for real-time data, such as audio and video
connections, which have stringent quality-of-service requirements.

• While less important for peer-to-peer transfers that consume all available
bandwidth, they are crucial for maintaining QoS commitments.
Leaky and Token Buckets
• Now we will look at a more general way to characterize traffic, with the leaky bucket and
token bucket algorithms. The formulations are slightly different but give an equivalent
result.
Try to imagine a bucket with a small hole in the bottom, as illustrated in Fig. 5-28(b). No
• matter the rate at which water enters the bucket, the outflow is at a constant rate, R, when
there is any water in the bucket and zero when the bucket is empty. Also, once the bucket
is full to capacity B, any additional water entering it spills over the sides and is lost.

• This bucket can be used to shape or police packets entering the network, as shown in Fig.
5-28(a). Conceptually, each host is connected to the network by an interface containing a
leaky bucket. To send a packet into the network, it must be possible to put more water into
the bucket. If a packet arrives when the bucket is full, the packet must either be queued
until enough water leaks out to hold it or be discarded.
• The former might happen at a host shaping its traffic for the network as part of the
operating system. The latter might happen in hardware at a provider network interface that
is policing traffic entering the network. This technique was proposed by Turner (1986) and
is called the leaky bucket algorithm.
• A different but equivalent formulation is to imagine the network interface as a bucket that
is being filled, as shown in Fig. 5-28(c). The tap is running at rate R and the bucket has a
capacity of B, as before. Now, to send a packet we must be able to take water, or tokens, as
the contents are commonly called, out of the bucket (rather than putting water into the
bucket).
• No more than a fixed number of tokens, B, can accumulate in the bucket, and if the

42
Module 3 The Network Layer
bucket is empty, we must wait until more tokens arrive before we can send another packet.
This algorithm is called the token bucket algorithm. Leaky and token buckets limit the
long-term rate of a flow but allow short term bursts up to a maximum regulated length to
pass through unaltered and without suffering any artificial delays.

• Large bursts will be smoothed by a leaky bucket traffic shaper to reduce congestion in the
network. As an example, imagine that a computer can produce data at up to 1000
Mbps(125 million bytes/sec) and that the first link of the network also runs at this speed.
• The pattern of traffic the host generates is shown in Fig. 5-29(a). This pattern is bursty.
The average rate over one second is 200 Mbps, even though the host sends a burst of
16,000 KB at the top speed of 1000 Mbps (for 1/8 of the second).

• Now suppose that the routers can accept data at the top speed only for short intervals, until
their buffers fill up. The buffer size is 9600 KB, smaller than the traffic burst. For long
intervals, the routers work best at rates not exceeding 200 Mbps (say, because this is all
the bandwidth given to the customer). The implication is that if traffic is sent in this
pattern, some of it will be dropped in the network because it does not fit into the buffers at
routers.

43
Module 3 The Network Layer
• To avoid this packet loss, we can shape the traffic at the host with a token bucket. If we
use a rate, R, of 200 Mbps and a capacity, B, of 9600 KB, the traffic will fall within what
the network can handle. The output of this token bucket is shown in Fig. 5-29(b).

• The host can send full throttle at 1000 Mbps for a short while until it has drained the
bucket. Then it has to cut back to 200 Mbps until the burst has been sent. The effect is to
spread out the burst over time because it was too large to handle all at once. The level of
the token bucket is shown in Fig. 5- 29(e).
• Fig. 5-29(c) shows the output of a token bucket with R = 200 Mbps and a capacity of 0.
This is the extreme case in which the traffic has been completely smoothed. No bursts are
allowed, and the traffic enters the network at a steady rate. The corresponding bucket level,
shown in Fig. 5-29(f), is always empty. Traffic is being queued on the host for release into
the network and there is always a packet waiting to be sent when it is allowed
• Calculating the length of the maximum burst (until the bucket empties) is slightly tricky. It
is longer than just 9600 KB divided by 125 MB/sec because while the burst is being
output, more tokens arrive. If we call the burst length S sec., the maximum output rate M
bytes/sec, the token bucket capacity B bytes, and the token arrival rate R bytes/sec, we can
see that an output burst contains a maximum of B + RS bytes. We also know that the
number of bytes in a maximum speed burst of length S seconds is MS. Hence, we have
B + RS = MS
• We can solve this equation to get S = B /(M − R). For our parameters of B = 9600 KB, M
= 125 MB/sec, and R = 25 MB/sec, we get a burst time of about 94 msec. A potential
problem with the token bucket algorithm is that it reduces large bursts down to the long- term
rate R. Using all of these buckets can be a bit tricky. When token buckets are used for traffic shaping at
hosts, packets are queued and delayed until the buckets permit them to be sent. When token buckets are
used for traffic policing at routers in the network, the algorithm is simulated to make sure that no more
packets are sent than permitted. Nevertheless, these tools provide ways to shape the network traffic into
more manageable forms to assist in meeting quality-of-service requirements.

5.4.4 Packet Scheduling

• Regulating Traffic Shape:

• Regulating the shape of offered traffic is a crucial step.

• However, providing a performance guarantee requires reserving sufficient resources

44
Module 3 The Network Layer
along the route that packets take through the network.

• Consistent Packet Routing:

• Assumption: For performance guarantees, packets of a flow must follow the same
route.

• Randomly spraying packets over routers makes it challenging to ensure any


guarantees.

• Virtual Circuit Setup:

• To address routing consistency, something akin to a virtual circuit must be established


from the source to the destination.

• All packets belonging to a specific flow must follow this established route.

• Packet Scheduling Algorithms:

• Algorithms that allocate router resources among packets of a flow and manage
resources between competing flows are known as packet scheduling algorithms.

• These algorithms play a crucial role in ensuring that resources are appropriately
distributed to meet performance guarantees.
Three different kinds of resources can potentially be reserved for different flows:

• Bandwidth Reservation:

• Bandwidth is a critical resource.

• If a flow requires 1 Mbps and the outgoing line has a capacity of 2 Mbps, reserving
bandwidth means not oversubscribing the output line.

• Buffer Space Allocation:

• Buffer space is another crucial resource.

• Packets arriving at a router are buffered until they can be transmitted on the chosen
outgoing line.

• Buffers absorb small bursts of traffic as flows contend with each other.

• For quality of service, some buffers might be reserved for specific flows,
preventing competition with other flows for buffer space.

45
Module 3 The Network Layer
• Maintaining a reserve ensures that a buffer is available when a flow needs it, up to
a specified maximum value.

• CPU Cycle Management:

• CPU cycles in routers are a potential scarce resource.

• Processing a packet consumes router CPU time, limiting the number of packets the
router can handle per second.

• Certain packets, such as ICMP packets, may require more CPU processing.

• Avoiding CPU overload is essential to ensure timely processing of packets,


particularly those that demand additional computational resources.
Packet Scheduling Algorithms:

• Packet scheduling algorithms allocate bandwidth and other router resources by


determining which buffered packets to send on the output line next.
FIFO (First-In First-Out) Scheduling

• FIFO is the most straightforward scheduler.


• Each router maintains queues for each output line, buffering packets until they can be sent.
• Packets are sent in the same order they arrived, following the First-In First-Out (FIFO) or
First-Come First-Serve (FCFS) principle.
Tail Drop in FIFO Routers:
• FIFO routers often drop newly arriving packets when the queue is full.
• This behaviour is known as tail drop, where the newly arrived packet is dropped since it
would have been placed at the end of the full queue.

• Various scheduling algorithms create different opportunities for deciding which packet to
drop when buffers are full.
Challenges of FIFO for Quality of Service:

• FIFO scheduling is simple but not ideal for providing good quality of service.
• In scenarios with multiple flows, an aggressive sender in the first flow can adversely
impact the performance of other flows.
• Aggressive senders can hog router capacity, starving other flows and reducing their quality
of service.

46
Module 3 The Network Layer
• The order-of-arrival processing in FIFO can lead to delays for packets of other flows,
exacerbating the impact of aggressive senders.

• Many packet scheduling algorithms have been devised that provide stronger isolation
between flows and thwart attempts at interference (Bhatti and Crowcroft, 2000). One of
the first ones was the fair queueing algorithm devised by Nagle (1987). When the line
becomes idle, the router scans the queues round-robin, as shown in Fig. 5-30.
• It then takes the first packet on the next queue. In this way, with n hosts competing for the
output line, each host gets to send one out of every n packets. It is fair in the sense that all
flows get to send packets at the same rate. Sending more packets will not improve this rate.
Although a start, the algorithm has a flaw: it gives more bandwidth to hosts that use large
packets than to hosts that use small packets. Demers et al suggested an improvement
in which the round-robin is done in such a way as to simulate a byte-by-byte round-robin,
instead of a packet-by-packet round-robin.
• The trick is to compute a virtual time that is the number of the round at which each packet
would finish being sent. Each round drains a byte from all of the queues that have data to
send. The packets are then sorted in order of their finishing times and sent in that order.
This algorithm and an example of finish times for packets arriving in three flows are
illustrated in Fig. 5-31. If a packet has length L, the round at which it will finish is simply
L rounds after the start time. The start time is either the finish time of the previous
packet,time of the packet, if the queue is empty when it arrives or the arrival.

47
Module 3 The Network Layer

• From the table in Fig. 5-32(b), and looking only at the first two packets in the top two
queues, packets arrive in the order A, B, D, and F. Packet A arrives at round 0 and is 8
bytes long, so its finish time is round 8. Similarly, the finish time for packet B is 11.
Packet D arrives while B is being sent. Its finish time is 9 byte-rounds after it starts when
B finishes, or 20. Similarly, the finish time for F is 16. In the absence of new arrivals, the
relative sending order is A, B, F, D, even though F arrived after D. It is possible that
another small packet will arrive on the top flow and obtain a finish time before D. It will
only jump ahead of D if the transmission of that packet has not started
• One shortcoming of this algorithm in practice is that it gives all hosts the same priority. In
many situations, it is desirable to give, for example, video servers more bandwidth than,
say, file servers. This is easily possible by giving the video server two or more bytes per
round. This modified algorithm is called WFQ (Weighted Fair Queueing). Letting the
number of bytes per round be the weight of a flow, W, we can now give the formula for
computing the finish time:

Fi = max(Ai,Fi −1)+Li /W

• where Ai is the arrival time, Fi is the finish time, and Li is the length of packet i. The
bottom queue of Fig. 5-31(a) has a weight of 2, so its packets are sent more quickly as you
can see in the finish times given in Fig. 5-31(b).
• As a final example of a scheduler, packets might carry timestamps and be sent in
timestamp order. Clark et al. (1992) describes a design in which the timestamp records
how far the packet is behind or ahead of schedule as it is sent through a sequence of
routers on the path. Packets that have been queued behind other packets at a router will
tend to be behind schedule, and the packets that have been serviced first will tend to be
ahead of schedule. Sending packets in order of their timestamps has the beneficial effect of
speeding up slow packets while at the same time slowing down fast packets. The result is
that all packets are delivered by the network with a more consistent delay.
5.4.5 Admission Control
• QoS Elements and Admission Control:

• QoS guarantees are established through the process of admission control.

• Admission control was initially used to control congestion, providing a weak


performance guarantee.

48
Module 3 The Network Layer

• The network decides to accept or reject the flow based on its capacity and
commitments to other flows.

• Reservations and Path Considerations:

• Reservations must be made at all routers along the route to prevent congestion.

• Some routing algorithms send all traffic over the best path, potentially causing
rejection of flows if there's insufficient spare capacity.

• QoS routing and splitting traffic over multiple paths are techniques to
accommodate QoS guarantees for new flows.

• Complexity in Acceptance or Rejection Decision:

• The decision to accept or reject a flow involves more than comparing requested
resources with router excess capacity.

• Applications may not have knowledge of buffers or CPU cycles, necessitating a


different way to describe flows and translate descriptions to router resources.

• Tolerance Levels and Guarantees:

• Some applications are more tolerant of occasional missed deadlines than others.

• Applications must choose between hard guarantees or behavior that holds most of
the time.

• Hard guarantees are expensive due to constraining worst-case behavior, so many


applications are satisfied with guarantees for most packets.

• Negotiation of Flow Parameters:

• Some applications may be willing to adjust flow parameters, while others may not..

• Properties like the number of pixels per frame and audio bandwidth may be
negotiable for certain applications.

• Importance of Accurate Flow Description:

• Due to the involvement of multiple parties in flow negotiation (sender, receiver,


routers along the path), accurate flow description is crucial.

49
Module 3 The Network Layer
• Flows need to be described in terms of specific negotiable parameters.

• Flow Specification:

• A set of parameters that describe a flow is termed a flow specification.

• The sender, such as a video server, typically generates a flow specification


proposing desired parameters.

• As the specification travels along the route, each router may modify parameters as
necessary, but modifications can only reduce the flow, not increase it.

• Parameter Modifications:

• Each router along the path examines and modifies the flow specification.

• Modifications are allowed to decrease the flow, such as lowering the data rate, but
not to increase it.

• Establishment of Parameters:

• When the flow specification reaches the destination, the negotiated parameters can
be established.

• Queueing Delay and Burst Size:

• The largest queueing delay experienced by a flow is a function of the burst size of
the token bucket.

• In cases of smooth traffic without bursts, packets are drained from the router as
quickly as they arrive, resulting in no queueing delay (ignoring packetization
effects).

• Conversely, if traffic is saved up in bursts, the maximum queueing delay occurs


when a maximum-size burst arrives at the router all at once. The maximum delay is
the time taken to drain this burst at the guaranteed bandwidth, or B/R (ignoring
packetization effects).

• Guarantees and Token Buckets:

• Guarantees provided by token buckets are hard guarantees.

• Token buckets limit the burstiness of the traffic source.

50
Module 3 The Network Layer
• Fair queueing isolates the bandwidth allocated to different flows, ensuring that
each flow meets its bandwidth and delay guarantees regardless of the behaviour of
other competing flows at the router.

• Isolation of Flows:

• Competing flows at the router cannot break the guarantee even if they save up
traffic and send it all at once.

• The combination of token buckets and fair queueing ensures that each flow's
guarantees remain intact.

• Path Through Multiple Routers:

• The guarantees hold for a path through multiple routers in any network topology.

• Each flow receives a minimum bandwidth at each router, as guaranteed.

• Maximum delay for each flow is ensured, even in the worst-case scenario where a
burst of traffic hits the first router and competes with other flows. The burst's delay
is at most D, and this delay smooths the burst, preventing further queueing delays
at later routers.

5.4.6 Integrated Services


• Timeframe and Efforts (1995-1997):

• Between 1995 and 1997, the Internet Engineering Task Force (IETF) dedicated
substantial effort to creating an architecture for streaming multimedia.

• This initiative resulted in over two dozen RFCs, starting with RFCs 2205–2212.

• The overarching name for this work is "integrated services," addressing both
unicast and multicast applications.

• Integrated Services Aimed at Unicast and Multicast:

• The integrated services architecture was designed to cater to both unicast and
multicast applications.

• Unicast example: a single user streaming a video clip from a news site.

• Multicast example: digital television stations broadcasting their programs as IP


packet streams to many receivers at various locations.

51
Module 3 The Network Layer
• Focus on Multicast:

• The discussion will concentrate on multicast, considering unicast as a special case


of multicast.

• Dynamic Group Membership in Multicast:

• In many multicast applications, groups can dynamically change membership.

• Examples include people joining and leaving a video conference or switching


between different channels (e.g., a soap opera or the croquet channel).

• Challenges with Bandwidth Reservation for Dynamic Groups:

• Traditional approaches involving senders reserving bandwidth in advance do not


work well in dynamic multicast scenarios.

• Tracking entries and exits of the audience for each sender becomes impractical,
especially for systems transmitting television to a large number of subscribers
RSVP—The Resource reservation Protocol

• Visible Component of Integrated Services Architecture:

• The primary component of the integrated services architecture that is visible to


network users is RSVP (Resource Reservation Protocol).

• RSVP is detailed in RFCs 2205–2210.

• Other protocols are employed for the actual transmission of data.

• Functionality of RSVP:

• RSVP is responsible for making reservations in the network.

• It supports multiple senders transmitting to multiple groups of receivers.

• Allows individual receivers to switch channels freely.

• Optimizes bandwidth utilization and simultaneously eliminates congestion issues.

Simplest Form of RSVP:

• In its simplest form, RSVP utilizes multicast routing with spanning trees.

• Each multicast group is assigned a group address.

• To send to a group, a sender includes the group's address in its packets.

52
Module 3 The Network Layer
• The standard multicast routing algorithm constructs a spanning tree that covers all
members of the group.

• RSVP doesn't define the multicast routing algorithm but adds a little extra
information periodically multicast to the group. This information instructs routers
along the tree to maintain specific data structures in their memories.

As an example, consider the network of Fig. 5-34(a). Hosts 1 and 2 are multicast senders, and
hosts 3, 4, and 5 are multicast receivers. In this example, the senders and receivers are disjoint,
but in general, the two sets may overlap. The multicast trees for hosts 1 and 2 are shown in Fig. 5-
34(b) and Fig. 5-34(c), respectively.

• Improving Reception and Avoiding Congestion:

• To enhance reception quality and prevent congestion, any receiver within a group
has the capability to send a reservation message up the tree to the sender.

• Reservation Message Propagation:

• The reservation message is propagated using the reverse path forwarding


algorithm.

• The reverse path forwarding algorithm is a mechanism previously discussed.

• Failure Reporting for Insufficient Bandwidth:

• If there is insufficient bandwidth available at any point along the path, the router

53
Module 3 The Network Layer
reports back a failure in the reservation process.

• Reservation Completion:

• By the time the reservation message reaches the source (sender), bandwidth has
been successfully reserved all the way from the sender to the receiver who initiated
the reservation request.

• Spanning Tree Usage:

• The spanning tree, as established by the multicast routing algorithm, serves as the
path for the reservation message, ensuring that all routers along the way are
involved in the reservation process.

An example of such a reservation is shown in Fig. 5-35(a). Here host 3 has requested a channel to
host 1. Once it has been established, packets can flow from 1 to 3 without congestion. Now
consider what happens if host 3 next reserves a channel to the other sender, host 2, so the user can
watch two television programs at once. A second path is reserved, as illustrated in Fig. 5-35(b).
Note that two separate channels are needed from host 3 to router E because two independent
streams are being transmitted.

54
Module 3 The Network Layer

• Receiver's Reservation Options:

• When making a reservation, a receiver has the option to specify one or more
sources from which it wants to receive data.

• The receiver can indicate whether these source choices are fixed for the entire
duration of the reservation or if it wants the flexibility to change sources later.

• Optimizing Bandwidth Planning:

• Routers utilize the information provided by the receiver to optimize bandwidth


planning.

• Specifically, if two receivers agree not to change sources later on, routers can set
them up to share a path efficiently.

• Decoupling Reserved Bandwidth and Source Choice:

• In the fully dynamic case, reserved bandwidth is decoupled from the choice of the
data source.

• Once a receiver has reserved bandwidth, it can switch to another source while
retaining the portion of the existing path that is valid for the new source.

5.4.7 Differentiated Services

Flow-Based Quality of Service (QoS):

• Advantages:

• Offers good QoS for one or more flows by reserving necessary resources along the
route.

• Disadvantages:

• Requires advance setup for establishing each flow, which doesn't scale well with a
large number of flows.

• Maintains internal per-flow state in routers, making them vulnerable to crashes.

• Involves substantial changes to router code and complex router-to-router


exchanges for flow setup.

55
Module 3 The Network Layer
Class-Based Quality of Service (Differentiated Services - DiffServ):

• Approach:

• Simpler QoS approach, largely implemented locally in each router without advance
setup for the entire path.

• Utilizes an architecture called Differentiated Services (DiffServ), standardized by


IETF.

• Administrative Domain:

• Implemented by a set of routers forming an administrative domain (e.g., ISP or


telco).

• Defines service classes with corresponding forwarding rules.

• Packet Marking:

• If a customer subscribes to DiffServ, incoming packets are marked with the


corresponding class.

• Class information is carried in the Differentiated Services field of IPv4 and IPv6
packets.

• Traffic Conformance:

• Traffic within a class may be required to conform to specific shapes (e.g., leaky
bucket) or limitations.

• Ease of Implementation:

• Requires no advance setup, resource reservation, or time-consuming end-to-end


negotiation for each flow.

• Relatively easy to implement compared to flow-based schemes.

Comparison Example - Internet Telephony:

• Flow-Based Scheme:

• Each telephone call gets dedicated resources and guarantees.

56
Module 3 The Network Layer
• Class-Based Scheme:

• All telephone calls share resources reserved for the telephony class, preventing
interference from other classes.

• No individual telephone call receives private resources reserved exclusively for it.

Expedited Forwarding

Expedited Forwarding (EF) Service Class:

• Purpose:

• Designed to provide low-loss, low-delay, and low-jitter service.

• Suited for applications with stringent requirements, such as Voice over IP (VoIP).

• Two-Class System:

• Consists of two classes of service: regular and expedited.

• Majority of traffic is expected to be regular, and a limited fraction is designated as


expedited.

• Symbolic Representation:

• Represented as a "two-tube" system, emphasizing the separation of regular and


expedited traffic.

Note: There is one physical line; logical pipes illustrate reserved bandwidth for
different service classes.

57
Module 3 The Network Layer
• Implementation Strategy:
• Packets are classified as expedited or regular and marked accordingly.

• Classification may occur at the sending host or the ingress (first) router.

• Advantage of host-based classification: More information about packet flows is


available.

• Example: VoIP packets may be marked for expedited service by hosts.

• Traffic Policing:

• In cases where marking is done by the host, the ingress router may police the traffic to
ensure customers send only the allocated amount of expedited traffic.

• Queueing Mechanism:

• Routers within the network may have two output queues for each outgoing line: one
for expedited packets and one for regular packets.

• Arrival packets are queued accordingly, and the expedited queue is given priority over
the regular queue.

• Network Behaviour:

• Expedited packets, despite the actual presence of heavy regular traffic, experience the
network as unloaded due to priority treatment.

• Marking by Hosts:

• Facilitates the application of expedited service without requiring modifications to


existing applications.

• Common practice for VoIP packets, ensuring preferential treatment in supporting


networks.

58
Module 3 The Network Layer
• Assured Forwarding

Assured Forwarding Service Class:

• Objective:

• Aimed at managing service classes with greater complexity than expedited

forwarding.

• Described in RFC 2597.

• Priority Classes:
• Specifies four priority classes, each allocated specific resources.

• Top three classes often referred to as gold, silver, and bronze.

• Discard Classes:

• Defines three discard classes for packets experiencing congestion: low, medium,
and high.

• Combining priority and discard classes results in 12 service classes.

• Packet Processing Steps:

1. Packet Classification:

• Classify packets into one of the four priority classes.

• Classification can occur on the sending host or the ingress router.

• Rate of higher-priority packets may be limited as part of the service


offering.

2. Discard Class Determination:

• Pass packets through a traffic policer (e.g., token bucket) to identify discard
class.

59
Module 3 The Network Layer
• Low discard for packets within small bursts, medium discard for those
exceeding small bursts, and high discard for packets exceeding large bursts.

• Encode priority and discard class in each packet.

3. Router Processing:

• Routers in the network use a packet scheduler to handle different classes.

• Weighted fair queueing commonly employed for the four priority classes.

• Higher-weighted classes receive more bandwidth, preventing starvation of


lower classes.

• Preferential Dropping:

• Within a priority class, packets with a higher discard class can be preferentially
dropped.

• Algorithms like RED (Random Early Detection) may be used, starting to drop
packets before buffer space is exhausted during congestion.

• Enables acceptance of low discard packets while dropping high discard packets.

• Packet Scheduler:

• Implementation may involve weighted fair queueing, giving higher weights to


higher-priority classes.

• Ensures that higher-priority classes receive a larger share of bandwidth.

• Complexity and Flexibility:

• Assured forwarding introduces a more elaborate scheme, allowing for nuanced


management of service classes.

• Offers flexibility in handling different classes and responding to congestion


scenarios.

60
Module 3 The Network Layer

61

You might also like