Our project is a robust implementation of the Distance-Vector Routing protocol in Python. The implementation uses a variety of concepts, including the Bellman-Ford algorithm, socket programming, and multi-threading, to create a scalable and efficient solution for network routing.
To run the dvr.py
file in a repository, you can use the following command in your terminal:
python dvr.py <router-name> <router-port> <router-info-text>
Make sure you are in the correct directory where the dvr.py
file is located before running this command. The python
command will execute the code in the file and display any output or errors in the terminal. network topology information must be kept in a text file, in this case we are using "a.txt" for A router.
2
<router-name> <router-link-cost> <router-port>
B 2 3001
C 3 3002
Now run
python DVR.py A 3001 a.txt
do the similiar for other routers (B, C), then if you update one link, all the router will get updated.
We have implemented our program in Python, leveraging the object-oriented paradigm to create two key classes that are used throughout the codebase: 'adjacent node' and 'possible path'.
- 'adjacent node' refers to the link between any two nodes that are directly connected to each other.
- 'possible path' refers to the link between any two nodes that may or may not be directly connected to each other. It is worth noting that every adjacent node is a path, but not every path is necessarily a adjacent node.
Our program comprises several threads, including both permanent and temporary threads.
Listening: This thread listens for “Distance Vectors” sent by the adjacent nodes and creates a temporary Bellman-Ford thread when an update is detected.
- UserPrompt: This thread acts as the main interface for the program. The interface (menu) presents the user with four options:
- To view the shortest paths to the other routers in the network.
- To view the whole distance vector table.
- To edit the link cost(s).
- To quit the program.
- Checking Timeout: This thread determines whether a router is dead or not. After every second, it checks if all the adjacent nodes are listening at their designated ports. If an exception is found, the router is considered to be dead.
- Distance Vector Algorithm: This thread executes the Bellman-Ford algorithm on the distance vectors it has received from the adjacent nodes. It is started whenever an updated Distance Vector is received from a adjacent node.
- Distance Vector Share: This thread sends the router’s Distance Vector to all the adjacent nodes. It is created every time an update in the Distance Vector is detected. To ensure that the program can cater for link cost changes and re-instantiation of routers, the routers send their link cost in addition to the Distance Vector to the adjacent nodes so that the adjacent nodes can appropriately update the link cost.
The network was unable to converge when link costs increased, or a router failed due to the count-to-infinity problem. To counter this issue, we used the technique of 'Split Horizon with Reverse Poisoning.'
In some rare situations, this problem occurred in larger loops instead of just two routers. To resolve this, we did not execute the Bellman-Ford algorithm immediately after a router failure. Instead, we advertised the distance to the dead router as infinity first. This way, the adjacent nodes of the router became aware that the path was outdated, and the path to the dead router got expired (set as infinity), thus resolving the router looping problem.
When link costs changed through a given interface, there was no way for the other adjacent node to find out about the change. To make the cost of the link consistent in both directions, the router sends the updated link cost in addition to the Distance Vector to the concerned adjacent node. The adjacent node can then update the cost to the new value.
Whenever a router is created, it sends its link cost in addition to the Distance Vector to all adjacent nodes. When adjacent nodes receive this packet, they change the link cost to this router from 'infinity' to the specified value.
The project enabled us to apply theoretical concepts practically and provided us with a real-life networking issue to solve. We learned the intricacies of distance-vector routing protocols and their significance in modern networks.