Skip to content

davidezordan25/dncs-lab

 
 

Repository files navigation

DNCS-LAB

This repository contains the Vagrant files required to run the virtual lab environment used in the DNCS course.



        +-----------------------------------------------------+
        |                                                     |
        |                                                     |eth0
        +--+--+                +------------+             +------------+
        |     |                |            |             |            |
        |     |            eth0|            |eth2     eth2|            |
        |     +----------------+  router-1  +-------------+  router-2  |
        |     |                |            |             |            |
        |     |                |            |             |            |
        |  M  |                +------------+             +------------+
        |  A  |                      |eth1                       |eth1
        |  N  |                      |                           |
        |  A  |                      |                           |
        |  G  |                      |                     +-----+----+
        |  E  |                      |eth1                 |          |
        |  M  |            +-------------------+           |          |
        |  E  |        eth0|                   |           |  host-c  |
        |  N  +------------+      SWITCH       |           |          |
        |  T  |            |                   |           |          |
        |     |            +-------------------+           +----------+
        |  V  |               |eth2         |eth3                |eth0
        |  A  |               |             |                    |
        |  G  |               |             |                    |
        |  R  |               |eth1         |eth1                |
        |  A  |        +----------+     +----------+             |
        |  N  |        |          |     |          |             |
        |  T  |    eth0|          |     |          |             |
        |     +--------+  host-a  |     |  host-b  |             |
        |     |        |          |     |          |             |
        |     |        |          |     |          |             |
        ++-+--+        +----------+     +----------+             |
        | |                              |eth0                   |
        | |                              |                       |
        | +------------------------------+                       |
        |                                                        |
        |                                                        |
        +--------------------------------------------------------+



Requirements

How-to

  • Install Virtualbox and Vagrant
  • Clone this repository git clone https://github.com/fabrizio-granelli/dncs-lab
  • You should be able to launch the lab from within the cloned repo folder.
cd dncs-lab
[~/dncs-lab] vagrant up

Once you launch the vagrant script, it may take a while for the entire topology to become available.

  • Verify the status of the 4 VMs
[dncs-lab]$ vagrant status                                                                                                                                                                
Current machine states:

router                    running (virtualbox)
switch                    running (virtualbox)
host-a                    running (virtualbox)
host-b                    running (virtualbox)
  • Once all the VMs are running verify you can log into all of them: vagrant ssh router vagrant ssh switch vagrant ssh host-a vagrant ssh host-b vagrant ssh host-c

Assignment

This section describes the assignment, its requirements and the tasks the student has to complete. The assignment consists in a simple piece of design work that students have to carry out to satisfy the requirements described below. The assignment deliverable consists of a Github repository containing:

  • the code necessary for the infrastructure to be replicated and instantiated
  • an updated README.md file where design decisions and experimental results are illustrated
  • an updated answers.yml file containing the details of your project

Design Requirements

  • Hosts 1-a and 1-b are in two subnets (Hosts-A and Hosts-B) that must be able to scale up to respectively 267 and 253 usable addresses
  • Host 2-c is in a subnet (Hub) that needs to accommodate up to 25 usable addresses
  • Host 2-c must run a docker image (dustnic82/nginx-test) which implements a web-server that must be reachable from Host-1-a and Host-1-b
  • No dynamic routing can be used
  • Routes must be as generic as possible
  • The lab setup must be portable and executed just by launching the vagrant up command

Tasks

  • Fork the Github repository: https://github.com/fabrizio-granelli/dncs-lab
  • Clone the repository
  • Run the initiator script (dncs-init). The script generates a custom answers.yml file and updates the Readme.md file with specific details automatically generated by the script itself. This can be done just once in case the work is being carried out by a group of (<=2) engineers, using the name of the 'squad lead'.
  • Implement the design by integrating the necessary commands into the VM startup scripts (create more if necessary)
  • Modify the Vagrantfile (if necessary)
  • Document the design by expanding this readme file
  • Fill the answers.yml file where required (make sure that is committed and pushed to your repository)
  • Commit the changes and push to your own repository
  • Notify the examiner ([email protected]) that work is complete specifying the Github repository, First Name, Last Name and Matriculation number. This needs to happen at least 7 days prior an exam registration date.

Notes and References

Team members

This work has been developed by Davide Zordan (matr. number 202054, team leader) and Mattia Perin (matr. number 201980)

Design

The result of the script dcns-init is:

  • Subnet(hosts-a): 267 hosts;
  • Subnet(hosts-b): 253 hosts;
  • Subnet(Hub): 25 hosts.

Subnets

We decided to create 4 subnets, in order to respect the given tasks (math explanations in brackets):

  1. The first is between router-1 and router-2, with subnet 10.1.0.0/30 (private class-a addresses) because it has to cover only the 2 routers (232-30-2=2);
  2. The second is between router-1 and host-a, with subnet 192.168.0.0/23 (private class-c addresses) because it has to cover up to 267 hosts (232-23-2 = 510>267);
  3. The third is between router-1 and host-b, with subnet 192.168.2.0/24 (private class-c addresses) because it has to cover up to 253 hosts (232-24-2=254>253);
  4. The fourth is between router-2 and host-c, with subnet 192.168.3.0/27 (private class-c addresses) because it has to cover up to 25 hosts (232-27-2=30>25).

The table below shows in details the configuration for every device:

IP and VLANs

Device Interface IP Subnet
Router-1 enp0s9 (eth2) 10.1.0.1 1
Router-2 enp0s9 (eth2) 10.1.0.2 1
Router-1 enp0s8.10 (eth1) 192.168.0.1 2
Host-a enp0s8 (eth1) 192.168.0.2 2
Router-1 enp0s8.11 (eth1) 192.168.2.1 3
Host-b enp0s8 (eth1) 192.168.2.2 3
Router-2 enp0s8 (eth1) 192.168.3.1 4
Host-c enp0s8 (eth1) 192.168.3.2 4

We noticed that, with this type of simulation, interfaces use "Predictable Network Interface Names". So, we checked the corresponding names to eth1, eth2 and eth3. More details: https://www.freedesktop.org/wiki/Software/systemd/PredictableNetworkInterfaceNames/

Later, we proceeded to create 2 VLANs because we wanted to distinguish subnet 2 and 3. We assigned tag 10 for subnet-2 and tag 11 for subnet-3.

Network Design

Vagrant configuration

We created a bash script for each device with the required commands. In Vagrantfile, we added the specific path of each script to the corresponding device. After the command vagrant up, those scripts will configure the devices. We also increased the memory of host-c from 256 to 512 (MB), otherwise it would not be able to run the Docker image.

Devices configuration

IP assignation

We assigned an IP address to each interface with the command ip addr add [IP_ADDR] dev [INTERFACE]; Then we activated the interface with ip link set dev [INTERFACE] up

VLAN

In router-1 configuration, we used ip link add link enp0s8 name enp0s8.10 type vlan id 10 and ip link add link enp0s8 name enp0s8.11 type vlan id 11 and added IP addresses to the virtual interfaces with addr add 192.168.0.1/23 dev enp0s8.10 and ip addr add 192.168.2.1/24 dev enp0s8.11 to create respectively VLAN 10 and VLAN 11 and assign them to Subnet2 and Subnet3.

Forwarding

We enabled the option for IP forwarding in the two routers with sysctl -w net.ipv4.ip_forward=1

Routing

We used the command ip route add [IP_ADDR] via [GATEWAY_IP]. The first parameter corresponds to the network that we want to access; the second parameter is the next hop, that is the interface of the default gateway of the current subnet. Since we had to make the routes as generic as possible, we used for example in router-2 sudo ip route add 192.168.0.0/22 via 10.1.0.1. Doing that, we cover all IPs from 192.168.0.0 to 192.168.3.255, including all of our hosts.

Switch

We configured the switch and assigned VLAN tags to corresponding ports with these commands as superuser:

ovs-vsctl add-br switch                    
ovs-vsctl add-port switch enp0s8               
ovs-vsctl add-port switch enp0s9 tag="10"      
ovs-vsctl add-port switch enp0s10 tag="11"  

Docker

Here we had to include the docker instructions in host-c as requested. So, we executed the following commands as superuser:

apt-get update
apt-get -y install docker.io
systemctl start docker
systemctl enable docker
docker pull dustnic82/nginx-test
docker run --name nginx -p 80:80 -d dustnic82/nginx-test

Results

First at all, we successfully executed ping command (ping 192.168.2.2) from Host-a to Host-b. Then, we pinged from Host-a and Host-b to Host-c to check the correct forwarding between the subnets.

Finally, we executed curl 192.168.3.2 instruction from both Host-a and Host-b.

We obtained this correct output:

<!DOCTYPE html>
<html>
<head>
<title>Hello World</title>
<link href="" rel="icon" type="image/png" />
<style>
body {
  margin: 0px;
  font: 20px 'RobotoRegular', Arial, sans-serif;
  font-weight: 100;
  height: 100%;
  color: #0f1419;
}
div.info {
  display: table;
  background: #e8eaec;
  padding: 20px 20px 20px 20px;
  border: 1px dashed black;
  border-radius: 10px;
  margin: 0px auto auto auto;
}
div.info p {
    display: table-row;
    margin: 5px auto auto auto;
}
div.info p span {
    display: table-cell;
    padding: 10px;
}
img {
    width: 176px;
    margin: 36px auto 36px auto;
    display:block;
}
div.smaller p span {
    color: #3D5266;
}
h1, h2 {
  font-weight: 100;
}
div.check {
    padding: 0px 0px 0px 0px;
    display: table;
    margin: 36px auto auto auto;
    font: 12px 'RobotoRegular', Arial, sans-serif;
}
#footer {
    position: fixed;
    bottom: 36px;
    width: 100%;
}
#center {
    width: 400px;
    margin: 0 auto;
    font: 12px Courier;
}

</style>
<script>
var ref;
function checkRefresh(){
    if (document.cookie == "refresh=1") {
        document.getElementById("check").checked = true;
        ref = setTimeout(function(){location.reload();}, 1000);
    } else {
    }
}
function changeCookie() {
    if (document.getElementById("check").checked) {
        document.cookie = "refresh=1";
        ref = setTimeout(function(){location.reload();}, 1000);
    } else {
        document.cookie = "refresh=0";
        clearTimeout(ref);
    }
}
</script>
</head>
<body onload="checkRefresh();">
<img alt="NGINX Logo" src="http://d37h62yn5lrxxl.cloudfront.net/assets/nginx.png"/>
<div class="info">
<p><span>Server&nbsp;address:</span> <span>172.17.0.2:80</span></p>
<p><span>Server&nbsp;name:</span> <span>0ed3525f20cb</span></p>
<p class="smaller"><span>Date:</span> <span>05/Feb/2021:08:17:25 +0000</span></p>
<p class="smaller"><span>URI:</span> <span>/</span></p>
</div>
<br>
<div class="info">
    <p class="smaller"><span>Host:</span> <span>192.168.3.2</span></p>
    <p class="smaller"><span>X-Forwarded-For:</span> <span></span></p>
</div>

<div class="check"><input type="checkbox" id="check" onchange="changeCookie()"> Auto Refresh</div>
    <div id="footer">
        <div id="center" align="center">
            Request ID: 21d9376b04b2200393fb4f92e3b00a2d<br/>
            &copy; NGINX, Inc. 2018
        </div>
    </div>
</body>
</html>

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Shell 58.3%
  • Python 41.7%