Routing Simulator
Routing Simulator
Simulator
Routing Simulator
Introduction
1
Project Report Routing
Simulator
Routing
here to there." In some cases, the term routing is used in a very strict
get from one place to. Since it is difficult to grasp the usefulness of
information that is acquired but never used, we employ the term routing to
refer in general to all the things that are done to discover and advertise
paths from here to there and to actually move packets from here to there
meaningful.
users in the remote part of the world to get to information and services
2
Project Report Routing
Simulator
by means of routing protocols that establish mutually consistent routing
host, they both must make decisions as to how to send the packet. To do
this, the router and the host consult a database for information known as
the routing table. This database is stored in RAM so that the lookup
3
Project Report Routing
Simulator
4
Project Report Routing
Simulator
5
Project Report Routing
Simulator
Routing Table
the address of the next element that is the next hop in the "best" path to its
controller consults the routing table to decide the next hop for the packet.
Not only the local information but the global information is also consulted
two ways. The first method is to manually configure the routing table
with routes for each destination network. This is known as static routing.
routing tables that are built and maintained automatically through and
Routing Table
6
Project Report Routing
Simulator
ongoing communication between routers. Periodically or on demand,
Router
Every router along the path has routing table with at least two fields:
arbitrarily large networks in this fashion, as long as there are routers with
2.3 1.3
interfaces on each subcomponent of the Network.
2.1
1.2
Router
3.3
Network 3
7
3.1
Project Report Routing
Simulator
8
Project Report Routing
Simulator
Packet
destination addresses, data length, sequence number and data type. The
9
Project Report Routing
Simulator
the packet is, the Network knows where it came from and where it wants
to go. The Network can store a packet, for hours if necessary, then
"freeze" it and still know what has to be done to deliver the data. Packets
are efficient for data transfer, but are not so attractive for real-time
Link
routers the messages are sent from one to other using the link. So link
the other alternative links to reach from source to destination. Hence link
10
Project Report Routing
Simulator
Routing Algorithm
Choices in Routing
11
Project Report Routing
Simulator
Routing algorithms often have one or more of the following design goals:
Optimality
select the best route, which depends on the metrics and metric weightings
used to make the calculation. One routing algorithm, for example, may
use a number of hops and delays, but may weight delay more heavily in
words, the routing algorithm must offer its functionality efficiently, with a
important when the software implementing the routing algorithm must run
12
Project Report Routing
Simulator
Routing algorithms must be robust, which means that they
junction points, they can cause considerable problems when they fail. The
best routing algorithms are often those that have withstood the test of time
Rapid convergence
Flexibility
13
Project Report Routing
Simulator
changes in network bandwidth, router queue size, and network delay,
determine the best route. Sophisticated routing algorithms can base route
Path Length
network link. In this case, path length is the sum of the costs associated
with each link traversed. Other routing protocols define hop count, a
14
Project Report Routing
Simulator
products, such as routers, that a packet must take en route from a source to
a destination.
Reliability
network link. Some network links might go down more often than others.
After a network fails, certain network links might be repaired more easily
or more quickly than other links. Any reliability factors can be taken into
administrators.
Delay
network links, the port queues at each router along the way, network
15
Project Report Routing
Simulator
be traveled. Because delay is a conglomeration of several important
Bandwidth
slower links. If, for example, a faster link is busier, the actual time
Load
Communication Cost
16
Project Report Routing
Simulator
Communication cost is another important metric, especially
because some companies may not care about performance as much as they
care about operating expenditures. Even though line delay may be longer,
they will send packets over their own lines rather than through the public
17
Project Report Routing
Simulator
Choices in Routing
use routing hierarchies. In a flat routing system, the routers are peers of
18
Project Report Routing
Simulator
amounts to a routing backbone. Packets from non-backbone routers travel
to the backbone routers, where they are sent through the backbone until
they reach the general area of the destination. At this point, they travel
from the last backbone router through one or more non-backbone routers
mindlessly sending the packet to the next stop. Other algorithms assume
determine the path through the inter network based on their own
calculations. In the first system, the hosts have the routing intelligence.
work within and between domains. The nature of these two algorithm
19
Project Report Routing
Simulator
intradomain- routing algorithm would not necessarily be an optimal
about the status of each link and processes this information to compute a
routing table for every node. It then distributes these tables to all the
20
Project Report Routing
Simulator
Routing Algorithms
21
Project Report Routing
Simulator
Algorithms Used
Flooding
Hot-Potato
Source Routing
Link state
22
Project Report Routing
Simulator
Flooding
packets. Interesting to note that all routes are discovered, including the
optimal one, so this is robust and high performance (best path is found
It could try to ensure that each router only floods any given packet once.
Could try to be a little more selective about what is forwarded and where.
The station initiating a packet stores the distance of the destination in the
submitted packet (or the largest distance in the network). Each node
reduces the counter by one, and resubmits the packet to all the adjacent
nodes (but not to the node from where it received the packet). Packets
with counter 0 are discarded. The destination node doesn't resubmit the
packet .
HOP1
23
Project Report Routing
Simulator
HOP2
24
Project Report Routing
Simulator
HOP3
Stages in Flooding
Advantages:
Highly robust
Suitable for setting virtual circuits
Useful for broadcasting
Disadvantage:
25
Project Report Routing
Simulator
Hot-potato routing, or deflection routing, the nodes of a
multiple packets contend for a single outgoing channel, packets that are
not buffered are dropped to avoid congestion. But in hot potato routing,
each packet that is routed is constantly transferred until it reaches its final
moving further away from its destination because it has to keep moving
through the network. This technique allows multiple packets to reach their
intermediate locations.
the messages in transit, thus causing the messages to move from node to
node each time. In other words, the messages are treated like hot
potatoes.
26
Project Report Routing
Simulator
Real Networks
Immediate applications
Optical Networks
Non-optical networks
27
Project Report Routing
Simulator
Source Routing
can specify the route that a packet should take through the network. As a
packet travels through the network, each router will examine the
"destination IP address" and choose the next hop to forward the packet to.
In source routing, the "source" (i.e. the sender) makes some or all of these
decisions.
In strict source routing, the sender specifies the exact route the
(LSRR), in which the sender gives one or more hops that the packet must
To : A
From : D
Via : T
Used with trace route in order to find all the routes between points on the
network.
28
Project Report Routing
Simulator
Troubleshooting
Trying to figure out from point "A" why machines "F" and "L" cannot
Performance
routes.
Hacking
Sometimes machines will be on the Internet, but will not be reachable. (It
some other machine that is reachable to both sides that forwards packets.
Someone can then reach that private machine from the Internet by source
29
Project Report Routing
Simulator
Distance Vector
(Also known as Bellman-Ford or Ford-Fulkerson)
each router. The table has an entry for every other router in the subnet,
with two pieces of information: the link to take to get to the router, and
the estimated distance from the router. For a router A with two outgoing
links L1, L2, and a total of four routers in the network, the routing table
B 5 L1
C 7 L1
D 2 L2
periodically to update each other on the state of the subnet (which makes
which is shorter than your path, you start using that neighbor as the route
30
Project Report Routing
Simulator
to that node. Notice that you don't actually know the route the neighbor
thinks is shorter - you trust his estimate and start sending packets that
way.
31
Project Report Routing
Simulator
32
Project Report Routing
Simulator
RIP
(Routing Information Protocol)
protocol that uses hop count as its metric. RIP is widely used for routing
declared dead if a peer does not hear from it from 180 sec. The protocol
uses split horizon with poisonous reverse to avoid the count-to infinity
problem.
reflect the new route. The metric value for the path is increased by one,
and the sender is indicated as the next hop. RIP routers maintain only the
best route (the route with the lowest metric value) to a destination. After
updates are sent independently of the regularly scheduled updates that RIP
routers send.
33
Project Report Routing
Simulator
Applications
metrics.
34
Project Report Routing
Simulator
Link-State Routing
Distance Vector by having everybody share their idea of the state of the
Neighbor discovery
Measure delay
Question arises: do you include time spent waiting in the router (i.e. load
not?
35
Project Report Routing
Simulator
Ideally, every router would get every other router data
the subnet with different ideas of the topology of the net at the same time.
Changes ripple through the system, but routers that are widely spread can
be using very different routing tables at the same time. This could result in
information packets from other routers, every router can locally compute a
Advantages
the world that they are the center of the universe and are directly
messages
36
Project Report Routing
Simulator
OSPF allows for load balancing among multiple routers
37
Project Report Routing
Simulator
Problem Definition
38
Project Report Routing
Simulator
Problem Definition
time.
better algorithm.
Where
η i is Efficiency of Router i
39
Project Report Routing
Simulator
40
Project Report Routing
Simulator
various links.
3. Various Statistics for the router like efficiency, average packet size are
4. Statistics for the link like propagation delay, buffers filled are to be
7. The statistics for the router and the link are to be calculated for every
500 m sec.
41
Project Report Routing
Simulator
8. A provision for redrawing the congestion table and network is to be
provided.
42
Project Report Routing
Simulator
System Design
43
Project Report Routing
Simulator
Design
Router
buffer. It consults the routing algorithm and places the appropriate packets
on the link from which packets are placed on the link and transmitted. The
router at the other end of the link picks up the packets from the link and
places them in its buffer. From the router's buffer packets are processed.
If yes the router reads the message and sends acknowledgement else it
sends it to the router buffer from which it is forwarded to the next router.
Id of router
Size of Network
Simcore object
Buffer object
44
Project Report Routing
Simulator
Routing Algorithm
Router Status
Checking Probability
Threshold
Start Delay
Router
Route
Generate Crash Receive Consult
Next
Packet Router Packet RouteAlgo
Packet
45
Project Report Routing
Simulator
Link
The link acts as a bridge between the two routers. There are
buffers at both ends of a link in which packets are placed while routing.
The link transmits the packets based on the propagation delay specified.
According to the delay the packets are sent immediately to the next router
occurs. If the link goes down packets in the link buffers are lost.
Head Packet
Tail Packet
Queue Size
Propagation Time
Bit Rate
Status of Link
46
Project Report Routing
Simulator
Simcore object
Link
Remove
Add Transfer
Packet
Packet Packet
Routing Algorithm
destination.
Processing of Packet
If the packet is for that router, we can use this method to send some kind
47
Project Report Routing
Simulator
A packet from the router's buffer will be selected to be routed
Routing
Algorithm
Route
Select Process
Packet
Packet Packet
Packet
through a link. The packets are dummy entities and are just required to
know that the path given by the routing algorithm is followed or not. The
Packet Source
Packet destination
Fragment Offset
48
Project Report Routing
Simulator
Total Size
Creation Time
Previous Router
Next Router
Hop count
Fragment Flag
Fragmented Flag
Fragment
fragments are numbered and are placed on links for transmission. At the
other end of the buffer, the fragments are again combined to get the
original packet.
49
Project Report Routing
Simulator
Sequence number
Fragment Number
Fragment Size
Fragment
Simulator. It takes the input from the input file and initializes the routers
constraint based on which packets are generated and lost. It consults the
routing algorithm and decides the path and gives instructions to the
50
Project Report Routing
Simulator
down, it downs a link and after sometimes brings it back to normal state.
It checks each and every condition of every other object in the system and
Header Size
Head of linked list containing packets which are on their path on a link
Tail of linked list containing packets which are on their path on a link
51
Project Report Routing
Simulator
Lost History
Gross Lost - lost but duplicate of packet may have reached destination
Throughput
52
Project Report Routing
Simulator
Filling the Table
53
Project Report Routing
Simulator
54
Project Report Routing
Simulator
INPUT FILE
Network
Configuration
Process
Manage
ROUTE r ROUTE
R R
BUFFERS OF ROUTERS
Level 0
55
Project Report Routing
Simulator
NETWORK
CONFIGURATION
Input
Manager
Input Input
ROUTER ROUTER
ROUTER
i ROUTER
j
i j
Process
Generat
ePackets
Packets
Generat
Send
e Ack.
Ack. Packets
Pkts
Pkts
BUFFERS OF ROUTERS
56
Level 1
Project Report Routing
Simulator
CONFIGURATION
Input
Manager
LINK
ROUTER
Level 1
57
Project Report Routing
Simulator
Set
Size of
Subnet
Set
Prob.
of router
down
ROUTER
Set Size
of Buffer
Set
Topolog
y
INPUT
CONFIGURATION
Set
Bit Rate
Set
Propaga
-tion
delay
Set Prob
LINK
of
Packet
loss on
Link
Set
Prob. of
Link
down Level 2 58
Project Report Routing
Simulator
BUFFER FOR
INCOMING LINK
L1
Generate Add
Packets Packets to
buffers
from ICL
Consult
R.A and
Process
Packets
BUFFERS OF OUT
GOING LINK L2
Level 2
59
Project Report Routing
Simulator
Request from
Router i Buffer for incoming link
Generat Add
e Packets
Packets to
Router
Request from
Router i
Consult
Routing
Algo
Information Select a
from Links Packet
to be
routed
Route Process
the Packets
Packets
Place on
out
Generat
going
e Ack’s
Links
Level 3 60
Project Report Routing
Simulator
Design Implemenation
Software Used
61
Project Report Routing
Simulator
The JDK 1.4 is a development environment for writing GUI
and applications that confirm to the Java core API. Its compiler and other
Java Tools:
62
Project Report Routing
Simulator
single jar
javaw.exe.
63
Project Report Routing
Simulator
User Documentation
Requirements:
The user has to install JRE 1.3 or above to run this Routing Simulator
1.0
How to Run
The user has to double click the executable jar file to run the
The user will see a window to operate the Routing Simulator 1.0.
Operating
First the user have to select the topology in the box provided in the
lower right corner of the screen then there will be a dialog appears on
the screen prompting the user to give number nods in the network enter
a positive integer then click “OK” button then on the left side of the
screen the network topology can be viewed with the selected no nodes.
The can view the routing tables for each and every router by just
clicking icon the routers for this the user have to select a algorithm in
the panel provided on the top right corner of the window then clicking
64
Project Report Routing
Simulator
The routing algorithm efficiency can be viewed by clicking the button
For the process of evaluating the Routing Algorithm one can even
crash the Router by right Clicking on the Router and selecting the
“Down” button in the popup menu the same process for reactivating a
router.
The user can also view the routing buffer by clicking the “Router
Buffer” option in the popup menu, before that user have to send some
The user also can use the short notes provided on different routing
“Help” menu.
65
Project Report Routing
Simulator
Testing
the system are correct the goal will be successfully achieved. System
related programs in the system. Each portion of the entire system is tested
against the entire module with both test and live data before the entire
1. Online - Response
router for the selected algorithm have to be displayed on the screen. The
router must crash immediately when it the “Down” button clicked in the
popup menu.
2. Stress Testing
66
Project Report Routing
Simulator
The purpose of stress testing is to prove that the system does
not malfunction under peak loads. In the simulator we test it with the
greater number of nodes and getting the correct results for each and every
router applying different routing algorithms. All the routers are purposely
The usability test verifies the user friendly nature of the system.
The user is asked to use only the documentation and procedure as a guide
67
Project Report Routing
Simulator
Sample Outputs
68
Project Report Routing
Simulator
69
Project Report Routing
Simulator
70
Project Report Routing
Simulator
71
Project Report Routing
Simulator
72
Project Report Routing
Simulator
73
Project Report Routing
Simulator
74
Project Report Routing
Simulator
75
Project Report Routing
Simulator
76
Project Report Routing
Simulator
77
Project Report Routing
Simulator
78
Project Report Routing
Simulator
79
Project Report Routing
Simulator
80
Project Report Routing
Simulator
Conclusion
81
Project Report Routing
Simulator
and gives the different statistics of the routers and links. By changing the
the results we obtain the optimal algorithm. The optimal algorithm for a
routing.
the Simulator has provision for the crashing of routers, it gives an idea of
feasible in real networks to test algorithms and then implement a best one,
82
Project Report Routing
Simulator
83
Project Report Routing
Simulator
Future Scope
generated.
This has the potential to be used as one of the tools for experimentation on
84