VirtualBox and GNS3

This section describes how to install and set up Cumulus VX with VirtualBox and GNS3 to create the two leaf and one spine topology shown below.

In the topology, leaf01 and leaf02 are the access layer switches on the network. leaf01 and leaf02 connect to spine01, which is the aggregation layer switch on the network. To facilitate additional configuration after the initial setup descibed in this guide, leaf01 and leaf02 also have two connections to each other.

Follow the steps below to:

  • Create three VMs (leaf01, leaf02, and spine01) and the network connections between them
  • Log into the switches
  • Perform basic switch configuration
  • Verify configuration

These steps were tested with Cumulus VX 4.2, VirtualBox version 6.1.12, and GNS3 version 2.2.11 on macOS version 10.14.6.

Create and Configure the VMs

The following procedure creates leaf01, leaf02, and spine01 and the network connections between them. This section assumes you have VirtualBox and GNS3 experience.

Download and Install the Software

  1. Download and install VirtualBox.
  2. Download and install GNS3.
  3. Download the VirtualBox OVA image.

Create VMs in VirtualBox

The Cumulus VX OVA image defines the CPU, memory, and disk requirements. Cumulus VX requires at least 768MB of RAM and 6GB of disk space.

CumulusVX versions 4.3 and later requires 2 vCPUs.

Follow these steps for each VM (leaf01, leaf02, and spine01)

  1. Open the VirtualBox application and select Import Appliance from the File menu.
  2. Browse for the OVA disk image you downloaded, click the Open button, then click Continue.
  3. In the Appliance settings, change the name of the VM to leaf01, then click Import to begin the import process.

  4. In the VirtualBox Manager window, right click the leaf01 VM, then select Clone.
  5. Change the name of the VM to leaf02, then click Continue.
  6. Make sure Full Clone is selected, then click Clone.
  7. Repeat steps 4 through 6 to create spine01.

Configure GNS3

  1. Open the GNS3 application and create a new project.

  2. From the GNS3 menu, select Preferences.

  3. From the left pane of the Preferences dialog, select VirtualBox. Then, in the Path to VBoxManage field, enter the location where you installed VBoxManage. For example: /usr/bin/VBoxManage.

  4. From the left pane, select VirtualBox VMs, then click New. The VM list shows the VirtualBox VMs you set up earlier.

  5. From the VM list, select leaf01, then click Finish. The VM you selected appears in the center pane. Repeat this step for leaf02 and spine01.

  6. Enable GNS3 to work with the network interfaces of the VirtualBox VMs:

    1. In the center pane, select leaf01 then click Edit.

    2. In the VirtualBox VM template configuration dialog, click the Network tab.

    3. Increase the number of Adapters to 4.

    4. From the Type dropdown, select Paravirtualized Network.

    5. Select Allow GNS3 to use any configured VirtualBox adapter.

    6. Click OK to save your settings and close the dialog.

    7. Repeat these steps for leaf02 and spine01, then click OK to close the Preferences dialog.

Create Network Connections

Create the network connections between leaf01, leaf02, and spine01, as shown in the two leaf, one spine topology above.

  1. Click (Browse all Devices button), then from the End Devices panel, drag leaf01, leaf02, and spine01 to the console.
  2. Click the (cable icon), then connect the leafs and spine by selecting the network interfaces, as shown in the Topology Summary below:
    • e1 in GNS3 corresponds to swp1 in Cumulus VX
    • e2 in GNS3 corresponds to swp2 in Cumulus VX
    • e3 in GNS3 corresponds to swp3 in Cumulus VX
  1. Start the VMs.

Log into the Switches

Log into each switch with the cumulus account and default password cumulus. When you log in for the first time, you are prompted to change the default password.

If you are using Cumulus VX 4.1.1 or earlier, the default password is CumulusLinux!. You are not prompted to change the default password.

For more information on the required password change, see the Cumulus Linux documentation.

Basic Switch Configuration

Run these commands on each switch to change the hostname and bring up the interfaces. Exit the switch, then log back in to see the new hostname at the prompt.

cumulus@cumulus:mgmt:~$ net add hostname leaf01
cumulus@cumulus:mgmt:~$ net add interface swp1,swp2,swp3
cumulus@cumulus:mgmt:~$ net commit
cumulus@cumulus:mgmt:~$ exit
cumulus@cumulus:mgmt:~$ net add hostname leaf02
cumulus@cumulus:mgmt:~$ net add interface swp1,swp2,swp3
cumulus@cumulus:mgmt:~$ net commit
cumulus@cumulus:mgmt:~$ exit
cumulus@cumulus:mgmt:~$ net add hostname spine01
cumulus@cumulus:mgmt:~$ net add interface swp1,swp2
cumulus@cumulus:mgmt:~$ net commit
cumulus@cumulus:mgmt:~$ exit

Verify Configuration

Run the following commands on each switch to verify the configuration:

It might take a few minutes for the LLDP information to update. If your command output is different from the output shown below, wait a few minutes, then run the command again.

cumulus@leaf01:mgmt:~$ net show lldp
LocalPort    Speed    Mode          RemoteHost     RemotePort
-----------  -------  ------------  ------------   ------------
swp1         1G       Default       spine01        swp1
swp2         1G       Default       leaf02         swp2
swp3         1G       Default       leaf02         swp3
cumulus@leaf02:mgmt:~$ net show lldp
LocalPort    Speed    Mode          RemoteHost     RemotePort
-----------  -------  ------------  ------------   ------------
swp1         1G       Default       spine01        swp2
swp2         1G       Default       leaf01         swp2
swp3         1G       Default       leaf01         swp3
cumulus@spine01:mgmt:~$ net show lldp
LocalPort    Speed    Mode          RemoteHost     RemotePort
-----------  -------  ------------  ------------   ------------
swp1         1G       Default       leaf01         swp1
swp2         1G       Default       leaf02         swp1

Run the following commands on each switch to show system information:

cumulus@leaf01:mgmt:~$ net show system
Hostname..............leaf01
Build.................Cumulus Linux 4.2.0
Uptime................0.00.23.740000
Model.................Cumulus VX
Memory................768MB
Disk..................6GB
Vendor Name...........Cumulus Networks
Part Number...........4.2.0
Base MAC Address......4:00:27:39:B1:12
Serial Number.........4:00:27:39:B1:12
Product Name..........VX

Next Steps

  • Read the Cumulus Linux User Guide to learn about using Cumulus Linux and test out features on your switches.
  • Visit the NVIDIA Cumulus web site, which offers many resources to help you understand Cumulus Linux.
  • Try some of the advanced configuration. You can update your virtual environment to be able to use the Cumulus Linux on demand self-paced labs (a quick and easy way to learn the fundamentals). You can also run the topology converter to simulate a custom network topology with VirtualBox and Vagrant, or KVM-QEMU and Vagrant.
  • Try NVIDIA AIR, which is a free, personal, virtual data center network that provides a low-effort way to see Cumulus Networks technology in action. This is a good way to try out Cumulus Linux if you have platform or disk limitations.