CN-R19 UNIT-4
CN-R19 UNIT-4
CN-R19 UNIT-4
NETWORK LAYER
The network layer is concerned with getting packets from the source all the way to the destination. Getting
to the destination may require making many hops at intermediate routers along the way. the network layer is the
lowest layer that deals with end-to-end transmission. To achieve its goals, the network layer must know about the
topology of the network (i.e., the set of all routers and links) and choose appropriate paths through it, even for
large networks.
Store-And-Forward Switching
Services Provided To Transport Layer
Implementation Of Connection Less Service
Implementation Of Connection-Oriented Service
Comparison Of Virtual-Circuit And Datagram Subnet
Store-And-Forward Switching :
The major components of the system are the carrier's equipment, shown inside the shaded oval, and the
customers' equipment, shown outside the oval. Host H1 is directly connected to one of the carrier's routers, A, by
a leased line. In contrast, H2 is on a LAN with a router, F, owned and operated by the customer. This router also
has a leased line to the carrier's equipment. We have shown F as being outside the oval because it does not belong
to the carrier, but in terms of construction, software, and protocols, it is probably no different from the carrier's
routers.
The network layer provides services to the transport layer at the network layer/transport layer interface.
This viewpoint leads to the conclusion that the network service should be connectionless, with primitives SEND
PACKET and RECEIVE PACKET and little else. In particular, no packet ordering and flow control should be
done, because the hosts are going to do that anyway and there is usually little to be gained by doing it twice.
If connectionless service is offered, packets are injected into the network individually and routed
independently of each other. No advance setup is needed. In this context, the packets are frequently called
datagrams (in analogy with telegrams) and the network is called a datagram network.
Suppose that the process P1 in the following figure has a long message for P2. It hands the message to the
transport layer, with instructions to deliver it to process P2 on host H2. The transport layer code runs on H1,
typically within the operating system. It prepends a transport header to the front of the message and hands the
result to the network layer, probably just another procedure within the operating system.
If connection-oriented service is used, a path from the source router all the way to the destination router
must be established before any data packets can be sent. This connection is called a VC (virtual circuit), in
analogy with the physical circuits set up by the telephone system, and the network is called a virtual-circuit
network. The idea behind virtual circuits is to avoid having to choose a new route for every packet sent.
Figure. Routing within a virtual-circuit network.
Here, host H1 has established connection 1 with host H2. This connection is remembered as the first
entry in each of the routing tables. The first line of A’s table says that if a packet bearing connection identifier 1
comes in from H1, it is to be sent to router C and given connection identifier 1. Similarly, the first entry at C
routes the packet to E, also with connection identifier 1.
The main function of the network layer is routing packets from the source machine to the destination
machine. In most networks, packets will require multiple hops to make the journey. The algorithms that choose
the routes and the data structures that they use are a major area of network layer design. The routing algorithm is
that part of the network layer software responsible for deciding which output line an incoming packet should be
transmitted on. Routing algorithms can be grouped into two major classes: nonadaptive and adaptive.
Nonadaptive algorithms do not base their routing decisions on any measurements or estimates of the
current topology and traffic. Adaptive algorithms, in contrast, change their routing decisions to reflect
changes in the topology, and sometimes changes in the traffic as well. These dynamic routing algorithms differ
in where they get their information.
It states that if router J is on the optimal path from router I to router K, then the optimal path from J to K
also falls along the same route. As a direct consequence of the optimality principle, we can see that the set of
optimal routes from all sources to a given destination form a tree rooted at the destination. Such a tree is called a
sink tree. Since a sink tree is indeed a tree, it does not contain any loops, so each packet will be delivered within
a finite and bounded number of hops. The goal of all routing algorithms is to discover and use the sink trees for
all routers.
Several algorithms for computing the shortest path between two nodes of a graph are known. This one is
due to Dijkstra (1959) and finds the shortest paths between a source and all destinations in the network. Each
node is labeled (in parentheses) with its distance from the source node along the best known path.
The distances must be non-negative, as they will be if they are based on real quantities like bandwidth and delay.
Initially, no paths are known, so all nodes are labeled with infinity. As the algorithm proceeds and paths are
found, the labels may change, reflecting better paths. A label may be either tentative or permanent.
Initially, all labels are tentative. When it is discovered that a label represents the shortest possible path from the
source to that node, it is made permanent and never changed thereafter.
3.2.3 Flooding
When a routing algorithm is implemented, each router must make decisions based on local knowledge, not
the complete picture of the network. A simple local technique is flooding, in which every incoming packet is sent
out on every outgoing line except the one it arrived on.
Flooding obviously generates vast numbers of duplicate packets, in fact, an infinite number unless some
measures are taken to damp the process. One such measure is to have a hop counter contained in the header of
each packet that is decremented at each hop, with the packet being discarded when the counter
reaches zero.
Ideally, the hop counter should be initialized to the length of the path from source to destination. If the
sender does not know how long the path is, it can initialize the counter to the worst case, namely, the full diameter
of the network. Flooding with a hop count can produce an exponential number of duplicate packets as the hop
count grows and routers duplicate packets they have seen before. A better technique for damming the flood is to
have routers keep track of which packets have been flooded, to avoid sending them out a second time. One
way to achieve this goal is to have the source router put a sequence number in each packet it receives from its
hosts. Each router then needs a list per source router telling which sequence numbers originating at that source
have already been seen. If an incoming packet is on the list, it is not flooded.
The distance vector routing algorithm is sometimes called by other names, most commonly the distributed
Bellman-Ford routing algorithm, after the researchers who developed it . It was the original ARPANET routing
algorithm.In distance vector routing, each router maintains a routing table indexed by, and containing one entry
for each router in the network.
This entry has two parts: The preferred outgoing line to use for that destination and an estimate of the distance to
that destination. The distance might be measured as the number of hops or using another metric. This updating
process is illustrated in Figure 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.
Figure: (a) A network. (b) Input from A, I, H, K, and the new routing table for J.
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.
The settling of routes to best paths across the network is called convergence. Distance vector routing is
useful as a simple technique by which routers can collectively compute shortest paths, but it has a serious
drawback in practice: although it converges to the correct answer, it may do so slowly. In particular, it
reacts rapidly to good news, but leisurely to bad news. Consider a router whose best route to destination X is long.
If, on the next exchange, neighbor A suddenly reports a short delay to X, the router just switches over to using the
line to A to send traffic to X. In one vector exchange, the good news is processed.
When A comes up, the other routers learn about it via the vector exchanges. For simplicity, we will
assume that there is a gigantic gong somewhere that is struck periodically to initiate a vector exchange at all
routers simultaneously. At the time of the first exchange, B learns that its left-hand neighbor has zero delay
to A. B now makes an entry in its routing table indicating that A is one hop away to the left. All the other routers
still think that A is down. At this point, the routing table entries for A are as shown in the second row of Fig. (a).
On the next exchange, C learns that B has a path of length 1 to A, so it updates its routing table to indicate a path
of length 2, but D and E do not hear the good news until later. Clearly, the good news is spreading at the rate of
one hop per exchange. In a network whose longest path is of length N hops, within N exchanges everyone will
know about newly revived links and routers.
Consider the Fig.(b), in which all the links and routers are initially up. Routers B, C, D, and E have distances to A
of 1, 2, 3, and 4 hops, respectively. Suddenly, either A goes down or the link between A and B is
cut (which is effectively the same thing from B’s point of view). At the first packet exchange, B does not hear
anything from A. Fortunately, C says ‘‘Do not worry; I have a path to A of length 2.’’ Little does B suspect that
C’s path runs through B itself. For all B knows, C might have ten links all with separate paths to A of length 2. As
a result, B thinks it can reach A via C, with a path length of 3. D and E do not update their entries for A on the first
exchange.
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:
When a router is booted, its first task is to learn who its neighbors are. It accomplishes this goal by
sending a special HELLO packet on each point-to-point line. The router on the other end is expected to send back
a reply giving its name. These names must be globally unique because when a distant router later hears
that three routers are all connected to F, it is essential that it can determine whether all three mean the same F.
Figure: (a) A network. (b) The link state packets for this network.
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.
Now Dijkstra’s algorithm can be run locally to construct the shortest paths to all possible destinations. The results
of this algorithm tell the router which link to
3.2.6 Hierarchical Routing
As networks grow in size, the router routing tables grow proportionally. Not only is router memory
consumed by ever-increasing tables, but more CPU time is needed to scan them and more bandwidth is
needed to send status reports about them. At a certain point, the network may grow to the point where it is
no longerfeasible for every router to have an entry for every other router, so the routing will have to be
done hierarchically, as it is in the telephone network.
When hierarchical routing is used, the routers are divided into what we will call regions. Each
router knows all the details about how to route packets to destinations within its own region but knows
nothing about the internal structure of other regions. When different networks are interconnected, it is
natural to regard each one as a separate region to free the routers in one network from having to
know the topological structure of the other ones.
Figure gives a quantitative example of routing in a two-level hierarchy with five regions. The full
routing table for router 1A has 17 entries, as shown in Fig. (b). When routing is done hierarchically, as in
Fig.(c), there are entries for all the local routers, as before, but all other regions are condensed into a
single router, so all traffic for region 2 goes via the 1B-2A line, but the rest of the remote traffic goes via
the 1C-3B line. Hierarchical routing has reduced the table from 17 to 7 entries. As the ratio of the number
of regions to the number of routers per region grows, the savings in table space increase.
An improvement is multidestination routing, in which each packet contains either a list of destinations
or a bit map indicating the desired destinations. When a packet arrives at a router, the router checks all the
destinations to determine the set of output lines that will be needed. The router generates a new copy of
the packet for each output line to be used and includes in each packet only those destinations
that are to use the line. In effect, the destination set is partitioned among the output lines. After a sufficient
number of hops, each packet will carry only one destination like a normal packet.
The idea for reverse path forwarding is elegant and remarkably simple.
When a broadcast packet arrives at a router, the router checks to see if the packet arrived on the link that is
normally used for sending packets toward the source of the broadcast. If so, there is an excellent chance
that the broadcast packet itself followed the best route from the router and is therefore the first copy to
arrive at the router. This being the case, the router forwards copies of it onto all links except the one it
arrived on. If, however, the broadcast packet arrived on a link other than the preferred one for
reaching the source, the packet is discarded as a likely duplicate.
Figure . Reverse path forwarding. (a) A network. (b) A sink tree. (c) The
tree built by reverse path forwarding.
An example of reverse path forwarding is shown in Fig.Part (a) shows a network, part (b) shows a sink
tree for router I of that network, and part (c) shows how the reverse path algorithm works. On the first
hop, I sends packets to F, H, J, and N, as indicated by the second row of the tree. Each of these packets
arrives on the preferred path to I (assuming that the preferred path falls along the sink tree) and is so
indicated by a circle around the letter. On the second hop, eight packets are generated, two by each of the
routers that received a packet on the first hop.
A spanning tree is a subset of the network that includes all the routers but contains no loops. Sink trees
are spanning trees. If each router knows which of its lines belong to the spanning tree, it can copy an
incoming broadcast packet onto all the spanning tree lines except the one it arrived on. This method makes
excellent use of bandwidth, generating the absolute minimum number of packets necessary to do the job.
On the other hand, broadcasting a packet is wasteful if the group consists of, say, 1000 machines
on a million-node network, so that most receivers are not interested in the message (or worse yet, they are
definitely interested but are not supposed to see it). Thus, we need a way to send messages to well-defined
groups that are numerically large in size but small compared to the network as a whole.
Sending a message to such a group is called multicasting, and the routing algorithm used is called
multicast routing. All multicasting schemes require some way to create and destroy groups and to
identify which routers are members of a group. How these tasks are accomplished is not of concern to the
routing algorithm. For now, we will assume that each group is identified by a multicast address
and that routers know the groups to which they belong.
Multicast routing schemes build on the broadcast routing schemes we have already studied,
sending packets along spanning trees to deliver the packets to the members of the group while making
efficient use of bandwidth. However, the best spanning tree to use depends on whether the group is dense,
with receivers scattered over most of the network, or sparse, with much of the network not belonging to
the group.
As an example, consider the two groups, 1 and 2, in the network shown in Fig.(a). Some routers
are attached to hosts that belong to one or both of these groups, as indicated in the figure. A spanning tree
for the leftmost router is shown in Fig.(b). This tree can be used for broadcast but is overkill for multicast,
as can be seen from the two pruned versions that are shown next. In Fig. (c), all the links that do not lead
to hosts that are members of group 1 have been removed. The result is the multicast spanning tree for the
leftmost router to send to group 1. Packets are forwarded only along this spanning tree, which is more
efficient than the broadcast tree because there are 7 links instead of 10. Fig.(d) shows the multicast
spanning tree after pruning for group 2. It is efficient too, with only five links this time. It also shows that
different multicast groups have different spanning trees.
Various ways of pruning the spanning tree are possible. The simplest one can be used if link state
routing is used and each router is aware of the complete topology, including which hosts belong to which
groups. Each router can then construct its own pruned spanning tree for each sender to the group in
question by constructing a sink tree for the sender as usual and then removing all links that do
not connect group members to the sink node. MOSPF (Multicast OSPF) is an example of a link state
protocol that works in this way.
Figure. (a) A network. (b) A spanning tree for the leftmost router. (c) A
multicast tree for group 1. (d) A multicast tree for group 2.
3.4 QUALITY OF SERVICE
Quality of service (QoS) refers to any technology that manages data traffic to reduce packet loss, latency
and jitter on the network. QoS controls and manages network resources by setting priorities for specific types of
data on the network. To quantitatively measure quality of service, several related aspects of the network service
are often considered, such as packet loss, bit rate, throughput, transmission delay, availability, jitter, etc.
In the field of computer networking and other packet-switched telecommunication networks, quality of service
refers to traffic prioritization and resource reservation control mechanisms rather than the achieved service
quality. Quality of service is the ability to provide different priority to different applications, users, or data flows,
or to guarantee a certain level of performance to a data flow.
Application Requirements
A stream of packets from a source to a destination is called a flow (Clark,
1988). A flow might be all the packets of a connection in a connection-oriented network, or all the packets sent
from one process to another process in a connectionless network.
Traffic shaping is a technique for regulating the average rate and burstiness of a flow of data that enters the
network. The goal is to allow applications to transmit a wide variety of traffic that suits their needs, including
some bursts, yet have a simple and useful way to describe the possible traffic patterns to the network. When a
flow is set up, the user and the network (i.e., the customer and the provider) agree on a certain traffic pattern (i.e.,
shape) for that flow.
Traffic shaping reduces congestion and thus helps the network live up to its promise. However, to make it work,
there is also the issue of how the provider can tell if the customer is following the agreement and what to do if the
customer is not. Packets in excess of the agreed pattern might be dropped by the network, or they might be
marked as having lower priority. Monitoring a traffic flow is called traffic policing.
• Traffic shaping is a technique for regulating the average rate and burstiness of a flow of data that enters
the network.
Two types of traffic shaping techniques.
Leaky Bucket :
Suppose we have a bucket in which we are pouring water in a random order but we have to get water in a fixed
rate, for this we will make a hole at the bottom of the bucket. It will ensure that water coming out is in a some
fixed rate, and also if bucket will full we will stop pouring in it.
The input rate can vary, but the output rate remains constant. Similarly, in networking, a technique called leaky
bucket can smooth out bursty traffic. Bursty chunks are stored in the bucket and sent out at an average rate.
Difference between Leaky and Token buckets –
If bucket is full in token Bucket , token are discard not packets. While in leaky bucket, packets are
discarded.
Token Bucket can send Large bursts can faster rate while leaky bucket always sends packets at constant
rate.
5.4.3 Packet Scheduling
Algorithms that allocate router resources among the packets of a flow and between competing flows are called
packet scheduling algorithms. Three different
kinds of resources can potentially be reserved for different flows:
1. Bandwidth.
2. Buffer space.
3. CPU cycles.
The first one, bandwidth, is the most obvious. If a flow requires 1 Mbps and the outgoing line has a capacity
of 2 Mbps, trying to direct three flows through that line is not going to work. Thus, reserving bandwidth means
not oversubscribing any output line.
A second resource that is often in short supply is buffer space. When a packet arrives, it is buffered inside
the router until it can be transmitted on the chosen outgoing line. The purpose of the buffer is to absorb small
bursts of traffic as the flows contend with each other. If no buffer is available, the packet has to be discarded since
there is no place to put it. For good quality of service, some buffers might be reserved for a specific flow so that
flow does not have to compete for buffers with other flows.
Finally, CPU cycles may also be a scarce resource. It takes router CPU time to process a packet, so a router
can process only a certain number of packets per second. While modern routers are able to process most packets
quickly, some kinds of packets require greater CPU processing.
5.5 INTERNETWORKING
When two or more networks are connected to form an internetwork, or more simply an internet.
In computer networks, a tunneling protocol is a communications protocol that allows for the movement
of data from one network to another. It involves allowing private network communications to be sent across a
public network, such as the Internet, through a process called encapsulation. A tunneling protocol may, for
example, allow a foreign protocol to run over a network that does not support that particular protocol, such as
running IPv6 over IPv4. Another important use is to provide services that are impractical or unsafe to be offered
using only the underlying network services, such as providing a corporate network address to a remote user
whose physical network address is not part of the corporate network.
Figure: Tunneling a packet from Paris to London.
As an example, think of an international bank with an IPv6 network in Paris, an IPv6 network in London and
connectivity between the offices via the IPv4 Internet. This situation is shown in Fig.The solution to this problem
is a technique called tunneling. To send an IP packet to a host in the London office, a host in the Paris office
constructs the packet containing an IPv6 address in London, and sends it to the multiprotocol router that connects
the Paris IPv6 network to the IPv4 Internet. When this router gets the IPv6 packet, it encapsulates the packet with
an IPv4 header addressed to the IPv4 side of the multiprotocol router that connects to the London IPv6 network.
That is, the router puts a (IPv6) packet inside a (IPv4) packet. When this wrapped packet arrives, the London
router removes the original IPv6 packet and sends it onward to the destination host.
Tunneling is widely used to connect isolated hosts and networks using other networks.
Each network or link imposes some maximum size on its packets. These limits have various causes, among them
1. Hardware (e.g., the size of an Ethernet frame).
2. Operating system (e.g., all buffers are 512 bytes).
3. Protocols (e.g., the number of bits in the packet length field).
4. Compliance with some (inter)national standard.
5. Desire to reduce error-induced retransmissions to some level.
6. Desire to prevent one packet from occupying the channel too long.
The result of all these factors is that the network designers are not free to choose any old maximum packet size
they wish.
Figure: (a) Transparent fragmentation. (b) Nontransparent fragmentation
With transparent fragmentation end hosts (sender and receiver) are unaware that fragmentation has taken
place. A gateway fragments a packet, and the next-hop gateway on the same network reassembles the fragments
back into the original packet.
The first strategy is to make fragmentation caused by a ‘‘smallpacket’’ network transparent to any
subsequent networks through which the packet must pass on its way to the ultimate destination. This option is
shown in Fig.
In this approach, when an oversized packet arrives at G1, the router breaks it up into fragments. Each
fragment is addressed to the same exit router, G2, where the pieces are recombined. In this way, passage through
the small-packet network is made transparent. Subsequent networks are not even aware that fragmentation has
occurred.
Transparent fragmentation is straightforward but has some problems. For one thing, the exit router must know
when it has received all the pieces, so either a count field or an ‘‘end of packet’’ bit must be provided.
The other fragmentation strategy is to refrain from recombining fragments at any intermediate routers. Once a
packet has been fragmented, each fragment is treated as though it were an original packet. The routers pass the
fragments, as shown in Fig.(b), and reassembly is performed only at the destination host.
1. Make sure it works. Do not finalize the design or standard until multiple prototypes have successfully
communicated with each other.
2. Keep it simple. When in doubt, use the simplest solution.
3. Make clear choices. If there are several ways of doing the same thing, choose one.
4. Exploit modularity. This principle leads directly to the idea of having protocol stacks, each of whose
layers is independent of all the other ones.
5. Expect heterogeneity. Different types of hardware, transmission facilities, and applications will occur on
any large network.
6. Avoid static options and parameters. If parameters are unavoidable (e.g., maximum packet size), it is best
to have the sender and receiver negotiate a value rather than defining fixed choices.
7. Look for a good design; it need not be perfect. Often, the designers have a good design but it cannot
handle some weird special case.
8. Be strict when sending and tolerant when receiving. In other words, send only packets that rigorously
comply with the standards, but expect incoming packets that may not be fully conformant and
try to deal with them.
9. Think about scalability. If the system is to handle millions of hosts and billions of users effectively, no
centralized databases of any kind are tolerable and load must be spread as evenly as possible over the
available resources.
10. Consider performance and cost. If a network has poor performance or outrageous costs, nobody will use
it.
An IPv4 datagram consists of a header part and a body or payload part. The header has a 20-byte fixed part and a
variable-length optional part. The header format is shown in Fig. The bits are transmitted from left to right and
top to bottom, with the high-order bit of the Version field going first.
The Version field keeps track of which version of the protocol the datagram belongs to. Version 4
dominates the Internet today. Since the header length is not constant, a field in the header, IHL, is provided
to tell how long the header is, in 32-bit words. The minimum value is 5, which applies when no options are
present. The maximum value of this 4-bit field is 15, The Differentiated services field is one of the few fields that
has changed its meaning (slightly) over the years. Originally, it was called the Type of service field. It was and
still is intended to distinguish between different classes of service. Various combinations of reliability and speed
are possible.
The Total length includes everything in the datagram—both header and data. The maximum length is
65,535 bytes. The Identification field is needed to allow the destination host to determine which packet a newly
arrived fragment belongs to. All the fragments of a packet contain the same Identification value.
Next comes an unused bit, Then come two 1-bit fields related to fragmentation. DF stands for Don’t
Fragment. It is an order to the routers not to fragment the packet. MF stands for More Fragments. All fragments
except the last one have this bit set. It is needed to know when all fragments of a datagram have arrived.
The Fragment offset tells where in the current packet this fragment belongs. All fragments except the last one in a
datagram must be a multiple of 8 bytes. The TtL (Time to live) field is a counter used to limit packet lifetimes. It
was originally supposed to count time in seconds, allowing a maximum lifetime of 255 sec. It must be
decremented on each hop and is supposed to be decremented multiple times when a packet is queued for a long
time in a router. The Protocol field tells it which transport process to give the packet to. TCP is one possibility,
but so are UDP and some others. The numbering of protocols is global across the entire Internet.
Since the header carries vital information such as addresses, it rates its own checksum for protection, the Header
checksum. The algorithm is to add up all the 16-bit halfwords of the header as they arrive, using one’s
complement arithmetic, and then take the one’s complement of the result. For purposes of this algorithm, the
Header checksum is assumed to be zero upon arrival.
The Source address and Destination address indicate the IP address of the source and destination network
interfaces. The Options field was designed to provide an escape to allow subsequent versions of the protocol to
include information not present in the original design.
A defining feature of IPv4 is its 32-bit addresses. Every host and router on the Internet has an IP address
that can be used in the Source address and Destination address fields of IP packets. It is important to note that an
IP address does not actually refer to a host. It really refers to a network interface, so if a host is on
two networks, it must have two IP addresses. IP addresses are written in dotted decimal notation. In this format,
each of the 4 bytes is written in decimal, from 0 to 255.
The class A, B, and C formats allow for up to 128 networks with 16 million hosts each, 16,384 networks
with up to 65,536 hosts each, and 2 million networks (e.g., LANs) with up to 256 hosts each (although a few of
these are special). Also supported is multicast (the class D format), in which a datagram is directed to
multiple hosts. Addresses beginning with 1111 are reserved for use in the future.
5.6.3 IP Version 6:
IP has been in heavy use for decades. It has worked extremely well, as demonstrated by the exponential growth of
the Internet. IPv6 (IP version 6) is a replacement design that does just that. It uses 128-bit addresses; a shortage of
these addresses is not likely any time in the foreseeable future. However, IPv6 has proved very difficult to deploy.
It is a different network layer protocol that does not really interwork with IPv4, despite many similarities.
Figure: The IPv6 fixed header (required)
The IPv6 header is shown in Fig. The Version field is always 6 for IPv6 (and 4 for IPv4). During the transition
period from IPv4, which has already taken more than a decade, routers will be able to examine this field to tell
what kind of packet they have.
The Differentiated services field (originally called Traffic class) is used to
distinguish the class of service for packets with different real-time delivery requirements. It is used with the
differentiated service architecture for quality of service in the same manner as the field of the same name in the
IPv4 packet.
The Flow label field provides a way for a source and destination to mark groups of packets that have the same
requirements and should be treated in the same way by the network, forming a pseudoconnection.
The Payload length field tells how many bytes follow the 40-byte header. The name was changed from the IPv4
Total length field because the meaning was changed slightly: the 40 header bytes are no longer counted as part of
the length.
The Next header field lets the cat out of the bag. The reason the header could be simplified is that there can be
additional (optional) extension headers.
The Hop limit field is used to keep packets from living forever. It is, in practice, the same as the Time to live field
in IPv4, namely, a field that is decremented on each hop.
Next come the Source address and Destination address fields.
5.6.4 Internet Control Protocols:
In addition to IP, which is used for data transfer, the Internet has several companion control protocols that
are used in the network layer. They include ICMP,
ARP, and DHCP.
The operation of the Internet is monitored closely by the routers. When something unexpected occurs
during packet processing at a router, the event is reported to the sender by the ICMP (Internet Control Message
Protocol). ICMP is also used to test the Internet. About a dozen types of ICMP messages are defined.
Each ICMP message type is carried encapsulated in an IP packet. The most important ones are listed in Fig.
The DESTINATION UNREACHABLE message is used when the router cannot
locate the destination or when a packet with the DF bit cannot be delivered because a ‘‘small-packet’’ network
stands in the way.
The TIME EXCEEDED message is sent when a packet is dropped because its TtL (Time to live) counter has
reached zero.
The PARAMETER PROBLEM message indicates that an illegal value has been detected in a header field. This
problem indicates a bug in the sending host’s IP software or possibly in the software of a router transited.
The SOURCE QUENCH message was long ago used to throttle hosts that were sending too many packets. When
a host received this message, it was expected to slow down.
The REDIRECT message is used when a router notices that a packet seems to be routed incorrectly. It is used by
the router to tell the sending host to update to a better route.
The ECHO and ECHO REPLY messages are sent by hosts to see if a given destination is reachable and currently
alive. Upon receiving the ECHO message, the destination is expected to send back an ECHO REPLY message.
The TIMESTAMP REQUEST and TIMESTAMP REPLY messages are similar, except that the arrival time of
the message and the departure time of the reply are recorded in the reply.
The ROUTER ADVERTISEMENT and ROUTER SOLICITATION messages are used to let hosts find nearby
routers. A host needs to learn the IP address of at least one router to be able to send packets off the local network.
Open Shortest Path First (OSPF) is a routing protocol for Internet Protocol (IP) networks. It uses a link
state routing (LSR) algorithm and falls into the group of interior gateway protocols (IGPs), operating within a
single autonomous system (AS).
OSPF is a widely used IGP in large enterprise networks. IS-IS, another LSR-based protocol, is more common in
large service provider networks.
Open Shortest Path First (OSPF) was designed as an interior gateway protocol, for use in an autonomous system
such as a local area network (LAN). It implements Dijkstra's algorithm, also known as the shortest path first
(SPF) algorithm. As a link-state routing protocol it was based on the link-state algorithm developed for the
ARPANET in 1980 and the IS-IS (Intermediate-System to Intermediate-System), routing protocol. OSPF was
first standardized in 1989.
Fifth, and related to the above, OSPF had to do load balancing, splitting the load over multiple lines. Most
previous protocols sent all packets over a single best route, even if there were two routes that were equally good.
Sixth, support for hierarchical systems was needed. OSPF supports both point-to-point links (e.g., SONET) and
broadcast networks (e.g., most LANs). OSPF operates by abstracting the collection of actual networks, routers,
and links into a directed graph in which each arc is assigned a weight (distance, delay, etc.).
A point-to-point connection between two routers is represented by a pair of arcs, one in each direction. Their
weights may be different. A broadcast network is represented by a node for the network itself, plus a node for
each router.
When a router boots, it sends HELLO messages on all of its point-to-point lines and multicasts them on
LANs to the group consisting of all the other routers. During normal operation, each router periodically floods
LINK STATE UPDATE messages to each of its adjacent routers. DATABASE DESCRIPTION messages give
the sequence numbers of all the link state entries currently held by the sender. Either partner can request link state
information from the other one by using LINK STATE REQUEST messages.
Border Gateway Protocol (BGP) is a standardized exterior gateway protocol designed to exchange
routing and reach ability information among autonomous systems (AS) on the Internet.
The Border Gateway Protocol makes routing decisions based on paths, network policies, or rule-sets
configured by a network administrator and is involved in making core routing decisions.
BGP may be used for routing within an autonomous system. In this application it is referred to as Interior
Border Gateway Protocol, Internal BGP, or iBGP. In contrast, the Internet application of the protocol may be
referred to as Exterior Border Gateway Protocol, External BGP, or eBGP.
Within a single AS, OSPF and IS-IS are the protocols that are commonly used. Between ASes, a different
protocol, called BGP (Border Gateway Protocol), is used. A different protocol is needed because the goals of an
intradomain protocol and an interdomain protocol are not the same. All an intradomain protocol has to do is move
packets as efficiently as possible from the source to the destination. It does not have to worry about politics. In
contrast, interdomain routing protocols have to worry about politics a great deal. For example, a corporate AS
might want the ability to send packets to any Internet site and receive packets from any Internet site.
BGP Messages:
• Open
• Announces AS ID
• Determines hold timer – interval between keep_alive or update messages, zero interval implies no
keep_alive
• Keep_alive
• Sent periodically (but before hold timer expires) to peers to ensure connectivity.
• Sent in place of an UPDATE message
• Notification
• Used for error notification
• TCP connection is closed immediately after notification
Basic Operations:
• Learns multiple paths via internal and external BGP speakers
• Picks the best path and installs in the forwarding table
• Policies applied by influencing the best path selection.
IGMP can be used for one-to-many networking applications such as online streaming video and gaming,
and allows more efficient use of resources when supporting these types of applications.
IGMP is used on IPv4 networks. Multicast management on IPv6 networks is handled by Multicast
Listener Discovery (MLD) which is a part of ICMPv6 in contrast to IGMP's bare IP encapsulation.
The Internet Group Management Protocol (IGMP) is an Internet protocol that provides a way for an
Internet computer to report its multicast group membership to adjacent routers. Multicasting allows one computer
on the Internet to send content to multiple other computers that have identified themselves as interested in
receiving the originating computer's content. Multicasting can be used for such applications as updating the
address books of mobile computer users in the field, sending out company newsletters to a distribution list, and
"broadcasting" high-bandwidth programs of streaming media to an audience that has "tuned in" by setting up a
multicast group membership.
IGMP has three types of messages: the query, the membership report, and the leave report. There are two
types of query messages, general and special.
A multicast router connected to a network has a list of multicast addresses of the groups with at least one
loyal member in that network. For each group, there is one router that has the duty of distributing the multicast
packets destined for that group.