Skip to content

davideparpinello/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 373 and 302 usable addresses
  • Host 2-c is in a subnet (Hub) that needs to accommodate up to 50 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 πŸ‘₯

This project was done by Baccichet Giovanni (202869) and Parpinello Davide (201494 - team leader).

Design πŸ’‘

We started by executing the dcns-init script, that returned us the different values that need to be the number of scalable hosts in the subnets:

  • Subnet (host-a): 373 hosts;
  • Subnet (host-b): 302 hosts;
  • Subnet (host-c): 50 hosts.

Subnets πŸ“‘

Considering the design requirements, we decided to create 4 subnets. Doing some math, we calculated the most efficient way to organise the IP addresses:

  1. Subnet 1 is between router-1 and router-2. We used private class-a addresses with the subnet 10.0.0.0/30 to cover only the 2 routers (232-30-2=2);
  2. Subnet 2 is between router-1 and host-a, and according to the design requirements it has a max number of host of 373. We used private class-c addresses for this subnet 192.168.1.0/23 (232-23-2 = 510>373);
  3. Subnet 3 is between router-1 and host-b. We used private class-c addresses with the subnet 192.168.3.0/23 to cover the 302 hosts (232-23-2=510>302);
  4. Subnet 4 is between router-2 and host-c. We used private class-c addresses with the subnet 192.168.5.0/26 to cover the 50 hosts (232-26-2=62>50).

VLANs and IP configurations πŸ’Ύ

Device Interface predictable name Interface IP Subnet
Router-1 enp0s9 eth2 10.0.0.1 1
Router-2 enp0s9 eth2 10.0.0.2 1
Router-1 enp0s8 eth1 192.168.1.1 2
Host-A enp0s8 eth1 192.168.1.2 2
Router-1 enp0s8 eth1 192.168.3.1 3
Host-B enp0s8 eth1 192.168.3.2 3
Router-2 enp0s8 eth1 192.168.5.1 4
Host-C enp0s8 eth1 192.168.5.2 4

We then proceeded to create 2 VLANs, respectively for the subnets 2 and 3 with Tag 10 and 30.

Vagrant configuration πŸ–₯

We included all the commands needed for the configuration of the network in a bash script for each of the devices. Those scripts will configure the network during the creation of the VMs, after the command vagrant up. These scripts are included in the Vagrantfile using the provision command. We also needed to increase the memory of host-c from 256 to 512 (MB), otherwise it would have been impossible to pull and run the Docker image; in order to do that we modified the option vb.memory.

Commands used πŸ”§

Since the newer Debian-based distros use predictable names for network interfaces, we had to check what interfaces corresponded to eth1, eth2 and eth3, to match the specifications given. We used the command dmesg | grep -i eth and put the results in the table above. Every other command from now has to be executed by the superuser (adding sudo before the command).

  • [IP] We then proceeded assigning an IP address to each interface, with the command ip addr add [IP_ADDR] dev [INTERFACE], then activating said interface with ip link set dev [INTERFACE] up;
  • [FORWARDING] Then we enabled the IPv4 forwarding in the routers with sysctl -w net.ipv4.ip_forward=1;
  • [VLAN] For creating the VLANs mentioned earlier, we used ip link add link enp0s8 name enp0s8.10 type vlan id 10 and ip link add link enp0s8 name enp0s8.30 type vlan id 30 and added IP addresses to the virtual interfaces with addr add 192.168.1.1/23 dev enp0s8.10 and ip addr add 192.168.3.1/23 dev enp0s8.30;
  • [ROUTE] To create a route we used the ip route add 192.168.5.0/26 via 10.0.0.2 command. The first parameter 192.168.5.0/26 corresponds to the network we want to reach, and after via there is the IP address of the next hop, that is the interface of the router placed in the subnet where the current host is. Every host that has to reach another subnet has specific routes that achieve this, but, in particular, some hosts have generic routes with destinations like 192.168.0.0/23, with the purpose of designing the routes as generic as possible, covering the range 192.168.0.0 - 192.168.5.255, that includes all of our host subnets.

Switch configuration πŸ”€

We then had to setup the switch, assigning the VLAN tags to the ports. We created a bridge named β€œswitch” with ovs-vsctl add-br switch. Then we configured the ports:

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

Host C configuration πŸ•Έ

Since one design requirement was for the Host C to run a docker image, we proceeded with its configuration:

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

To check if the Host C was reachable from the Host A and the Host B we executed from every one of them curl 192.168.5.2, resulting in the following 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>94517f31a525</span></p>
<p class="smaller"><span>Date:</span> <span>18/Nov/2020:20:41:38 +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.5.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: 14dcea7ac763ad5816ec0bd11edf21df<br/>
            &copy; NGINX, Inc. 2018
        </div>
    </div>
</body>
</html>

The output was correct.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Languages

  • Shell 57.4%
  • Python 42.6%