Running Cisco CML in Proxmox

For the past few years, I’ve been running all my virtual machines on VMware Workstation Pro, installed on Windows 11. While it worked well for the most part, there were a few recurring issues. Windows would occasionally reboot to install updates, and when it did, my VMs would go down with it. This dependency on Windows to keep my VMs running became frustrating. Recently, I switched to Proxmox, a type-1 hypervisor, and the difference has been night and day.

In this blog post, we'll go through how to install Cisco CML (specifically CML 2.8 Free Tier) on Proxmox. If you're looking to install Cisco CML on VMware Workstation, check out my other blog post linked below.

Cisco CML Free Tier (No Kidding)
My initial reaction was, ‘Cisco giving something away for free? That can’t be true!’ But it turns out, it is. I couldn’t wait to try it. I believe it’s limited to five nodes, but I’ll take it.

Nested Virtualization

Nested virtualization allows you to run virtual machines inside another virtual machine. Essentially, it enables a hypervisor to be run within a virtualised environment, which is a requirement for platforms like Cisco CML that simulate network devices within a VM.

To check if nested virtualization is enabled on your Proxmox server, you can run the following command.

root@proxmox-01:~# cat /sys/module/kvm_intel/parameters/nested  
Y  

If the output is Y, nested virtualization is enabled. If it’s N, it means it’s not enabled. As EVE-NG relies on nested virtualization support, it’s important to ensure this feature is enabled.

If nested virtualization is not enabled, I recommend following the official Proxmox guide to enable it. Here is a quick summary of how to enable nested virtualization on Proxmox.

For Intel CPUs

echo "options kvm-intel nested=Y" > /etc/modprobe.d/kvm-intel.conf  

For AMD CPUs (note the 1 instead of Y):

echo "options kvm-amd nested=1" > /etc/modprobe.d/kvm-amd.conf  

Reboot the server or reload the kernel module

modprobe -r kvm_intel  
modprobe kvm_intel  

You can check again and make sure it is now enabled.

root@proxmox:~# cat /sys/module/kvm_intel/parameters/nested  
Y  
Running EVE-NG in Proxmox
In this blog post, we’ll go through the steps to install EVE-NG in Proxmox. Most of the VM’s settings can be left at their default values, but there are a couple of changes I had to make.

Download the Cisco CML Image

Head over to the Cisco download page and select CML (2.8 Free Tier). You need a Cisco account, which is easy to create. Once you create the account and log in, download the highlighted ISO image.

You'll also need to download the 'reference image ISO file,' which contains all the node images, such as IOS, ASA, Ubuntu, etc. So, make sure to download both of these files.

Extract the two zip files and you will end up with two folders containing the ISO files we need for the next steps.

Proxmox Configuration

On the Proxmox side, the process is similar to creating any other VM. However, make sure to set the VM type to 'host' under the CPU tab, as this enables nested virtualization.

Here the name of the ISO file you need to choose is cml2_2.8.0-6_amd64-32.iso

I'm allocating 32GB of RAM but for smaller labs 16GB or even 8GB should be enough.

Once you've created the VM, before powering it on, go to Add > CD/DVD Drive and select the REFPLAT ISO file you downloaded. This file contains the node images needed for Cisco CML.

Starting the VM and Initial Setup

That's it, now you can start the VM. The installation is straightforward, just follow the prompts, and you’ll be done. It took me just under 10 minutes to complete.

Using Cisco CML

Once the installation is complete, open your browser and navigate to the IP address you assigned to the VM, for example: https://10.10.10.10.

And that's it! From here, you can add nodes and access the CLI console directly.

References

https://0x2142.com/how-to-setup-cml-on-proxmox/