Simulation of the routing protocol

Assignment Help Computer Networking
Reference no: EM133712707

Cloud Networking

Machine Problem: Routing Protocol

Introduction
In this MP, you will implement your own routing protocol. The basic approach you use can be either the link state (LS) or distance vector (DV) protocol - your choice. Regardless of which you use, your program will read a file to get the network's topology and what messages to send, and write to an output file a log of what happened to those messages (the path along which they were delivered).

The Router Program
Your program should contain a collection of imaginary routing nodes that carry out their routing protocol (using your choice of protocol, link state or distance vector). These imag- inary nodes are just data structures in your program. There is no socket programming involved. In other words, you will be simulating what happens in a distributed network, in a way that the simulation can run on a single machine.

We have provided a simple starter program for the MP along with the Makefiles for com- piling the programs. You are free to modify the code or add additional files, but make sure that the Makefile generates the appropriate executables (for more details see submission instructions at the end of this document).

Your program should first read the input, which consists of a network topology, the mes- sages (and their source/destination) that have to be sent across the network and the topol- ogy changes to the network. Your program should create the appropriate data structures (e.g. node, forwarding table, forwarding table entry, routing update etc.). You should update these data structures when you create the topology or when any of the changes are applied to the topology.

The core of the program is a simulation of the routing protocol. Here's roughly what you need to implement for the two protocols.
Distance Vector: In a distance vector protocol, nodes gossip with each other about their distances with each other. When a link comes up or an existing link either goes offline or has its cost changed, the nodes for that link register that change and send updated distances to their neighbors who then update their forwarding table entries based on it. They then further propagate their distance information to their neighbors and so on. Your program should have data structures representing the routing tables of each node. It should update the tables at a node when a new route has been found or a previously available route is no longer available, and should correctly propogate these changes across the (simulated) network.

Link State: In a link state protocol, nodes gossip with each other about the state of the topology. When a node detects that the topology has changed, it runs the shortest path algorithm to find the new routes. In a real network, topology updates (called Link State Advertisements) would be propagated among nodes, until eventually all nodes have a complete and up-to-date view of the topology after a change. For this MP, you do not have to simulate the message propagation. Instead, your program is given the topology change, and you can assume that all nodes have the complete up-to-date view of the topology, initially and after each change. Your program should simulate what happens at each node after it has learned of the initial topology or a change - specifically, the recomputation of routes for the current topology.

Once the routing tables have converged for the initial topology, for each node, write out the node's forwarding table (in ascending order of node ID, see "Output format" section for details). Then, have some of your nodes send messages to certain other nodes, with the data forwarded according to the nodes' forwarding tables. The sources, destinations, and message contents are specified in the message file; see below for format.

Then, one at a time, apply each line in the topology changes file (see below) in order. After each change, once the routing tables have re-converged, print out the forwarding tables and resend all of the messages. More specifically, because the topology has changed, your program will have to follow the (DV or LS) routing protocol to change its routing decisions and arrive at a correct forwarding table for the new network topology. Then, you should re-send the same set of messages, which now may follow updated paths.

Tie breaking
In general, you can follow a standard version of the routing algorithm, such as what we have discussed in lecture. However, there is an important detail. We would like everyone to have consistent output even on complex topologies, so we ask you to follow specific tie-breaking rules.
1. Distance Vector: when two equally good paths are available, your node should choose the one whose next-hop node ID is lower.

2. Link State: If a current-best-known path and newly found path are equal in cost, choose the path whose last node before the destination has the smaller ID.

Example: The source is 1, and the current-best-known path to destination 9 is 1 → 4 → 12 → 9. We are currently processing node 10 (i.e., considering routes through 10 to its neighbors). 1 → 2 → 66 → 4 → 5 → 10 → 9 costs the same as path
1 → 4 → 12 → 9. We will switch to the new path, since 10 < 12.

Input Formats

The program reads three files: the topology file, the message file, and the topology changes
file.
Your program will be run using the following commands:
./linkstate topofile messagefile changesfile
./distvec topofile messagefile changesfile
You only have to implement one of the these. The autograder will run both and take the highest score of the two programs.
All files have their items delimited by newlines. Each has a specific format and meaning, which we will describe next. The files we test your code with will follow these descriptions exactly, with nothing extraneous or improperly formatted.

Topology file
The topology file represents the initial topology. A line in the topology file represents a link between two nodes and is structued this way:
<ID of a node> <ID of another node> <cost of the link between them>
Example topology file:
1 2 8
2 3 3
2 5 4
4 1 1
4 5 1
This would correspond to a topology of Figure 1.

Changes file
The topology changes file represents a sequence of changes to the topology, to be applied one by one. The changes file has the same format as the topology file. The first line in the changes file is the first change to apply, second is the second, etc. Cost -999 (and only -999) indicates that the previously existing link between the two nodes is broken. (Real link costs are always positive; never zero or negative.) Example changes file:
2 4 1
2 4 -999
This would add a link between 2 and 4 with cost 1, and then remove it afterwards.

Messages file
The message file describes which nodes should send data to whom once the routing tables converge. (The tables should converge before any of the topology changes, as well as after each change). All messages in the message file should be sent every time the tables converge. So, if there are two message lines in the messagefile, and two changes in the changesfile, a total of 6 messages should be sent: 2 initially, 2 after the first change in changesfile has been applied, and 2 after the second line in changesfile has been applied.
A line in the message file looks like
<source node ID> <dest node ID> <message text>
Example message file:
1 here is a message from 2 to 1
5 this one gets sent from 3 to 5!
The message file would cause "here is a message from 2 to 1" to be sent from 2->1, and "this one gets sent from 3 to 5!" from 3->5. Note that node IDs could go to double digits.

Output Format
Write all output described in this section to a file called "output.txt". The output file will have the general layout as follows:
<forwarding table entries for node 1>
<forwarding table entries for node 2>
<forwarding table entries for node 3>
<forwarding table entries for node ...>
<message output line 1>
<message output line 2>
<message output line ...>
--- At this point, 1st change is applied
<forwarding table entries for node 1>
<forwarding table entries for node 2>
<forwarding table entries for node 3>
<forwarding table entries for node ...>

<message output line 1>
<message output line 2>
<message output line ...>
--- At this point, 2nd change is applied
<forwarding table entries for node 1>
<forwarding table entries for node 2>
<forwarding table entries for node 3>
<forwarding table entries for node ...>
<message output line 1>
<message output line 2>
<message output line ...>
--- And so on...
The format for a single forwarding table entry should be like:
<destination> <nexthop> <pathcost>
where nexthop is the neighbor we hand destination's packets to, and pathcost is the total cost of this path to destination. The table should be sorted by destination.

Example of forwarding table entries for node 2 from the example topology:

1 5 6
2 2 0
3 3 3
4 5 5
5 5 4

There is one single space in between each number, with each row on its own line. As you can see, the node's entry for itself should list the nexthop as itself, and the cost as 0. If a destination is not reachable, do not print its entry.

Your program should print all nodes' tables, sorted according to the node ID. So, the example for node 2 would have been preceded by a similarly formatted table for node 1, and followed by the tables of 3, 4, and 5.

When a message is to be sent, print the source, destination, path cost, path taken (including the source, but NOT the destination node), and message contents in the following format:
"from <x> to <y> cost <path_cost> hops <hop1> <hop2> <...> message <message>"
e.g. : "from 2 to 1 cost 6 hops 2 5 4 message here is a message from 2 to 1"

Print messages in the order they were specified in the messages file. If the destination is not reach- able, please say "from <x> to <y> cost infinite hops unreachable message <message>"

Please do not print anything else; any diagnostic messages or the like should be commented out before submission. However, if you want to organize the output a little, it's okay to print as many blank lines as you want in between lines of output.

Both messagefile and changesfile can be empty. In this case, the program should just print the forwarding table.

Reference no: EM133712707

Questions Cloud

What conditions could lead to changes in our own microflora : Provide a brief description of what conditions could lead to changes in our own microflora, allowing the fungus Candida albicans to causes disease candidiasis.
How can we christians-messengers of kingdom of god on earth : In other words, how can we Christians or followers of Jesus become faithful "instruments, signs, or messengers" of the Kingdom of God on earth?
Discuss ways the drug may selectively act on bacterial cells : A new chemotherapeutic drug kills bacteria but not humans. Discuss the possible ways the drug may selectively act on bacterial cells.
Identify two interventions to address the problem : Identify two interventions to address the problem. Remember, the theory should be driving the interventions.
Simulation of the routing protocol : CS 435 Cloud Networking, University of Illinois - Simulation of the routing protocol. Here's roughly what you need to implement for the two protocols
What can change our microbiomes for the better or worse : What physiological systems can alterations in the microbiome affect? What can change our microbiomes for the better or worse?
Observation of a worship service of a major world religion : By means of your observation of a worship service of a major world religion, you will gain a greater understanding and a new appreciation of the teachings.
What was the purpose of the dish soap : Doing a search on the internet, what was the purpose of the dish soap? Reword what you find in your own words. What is the purpose of the salt?
What were the main weaknesses of the article : What were the main weaknesses of the article? What implications do the results have for real life and/or for future research?

Reviews

Write a Review

Computer Networking Questions & Answers

  Networking and types of networking

This assignment explains the networking features, different kinds of networks and also how they are arranged.

  National and Global economic environment and ICICI Bank

While working in an economy, it has a separate identity but cannot operate insolently.

  Ssh or openssh server services

Write about SSH or OpenSSH server services discussion questions

  Network simulation

Network simulation on Hierarchical Network Rerouting against wormhole attacks

  Small internet works

Prepare a network simulation

  Solidify the concepts of client/server computing

One-way to solidify the concepts of client/server computing and interprocess communication is to develop the requirements for a computer game which plays "Rock, Paper, Scissors" using these techniques.

  Identify the various costs associated with the deployment

Identify the various costs associated with the deployment, operation and maintenance of a mobile-access system. Identify the benefits to the various categories of user, arising from the addition of a mobile-access facility.

  Describe how the modern view of customer service

Describe how the greater reach of telecommunication networks today affects the security of resources which an organisation provides for its employees and customers.

  Technology in improving the relationship building process

Discuss the role of Technology in improving the relationship building process Do you think that the setting of a PR department may be helpful for the ISP provider? Why?

  Remote access networks and vpns

safekeeping posture of enterprise (venture) wired and wireless LANs (WLANs), steps listed in OWASP, Securing User Services, IPV4 ip address, IPV6 address format, V4 address, VPN, Deploying Voice over IP, Remote Management of Applications and Ser..

  Dns

problems of IPV, DNS server software, TCP SYN attack, Ping of Death, Land attack, Teardrop attack, Smurf attack, Fraggle attack

  Outline the difference between an intranet and an extranet

Outline the difference between an intranet and an extranet A programmer is trying to produce an applet with the display shown in Figure 1 below such that whenever one of the checkboxes is selected the label changes to indicate correctly what has..

Free Assignment Quote

Assured A++ Grade

Get guaranteed satisfaction & time on delivery in every assignment order you paid with us! We ensure premium quality solution document along with free turntin report!

All rights reserved! Copyrights ©2019-2020 ExpertsMind IT Educational Pvt Ltd