Cisco VIRL on Packet

What Is Cisco VIRL?

Cisco VIRL – or Virtual Internet Routing Labs – is a network simulation framework that enables the rapid design, configuration, and testing of comprehensive network and service-delivery solutions.

VIRL has many applications and uses and can provide significant value to everyone from students, educators, network engineers, to the largest corporate network operations teams. Some typical use-cases include:

  • Learning basic network technologies
  • Delivering network, protocol, or solution training
  • Testing new features
  • Developing and testing new configurations in advance of live rollouts
  • Troubleshooting issues observed in live networks
  • Validating changes as part of a DevOps / NetOps tool-chain
  • Delivering demonstrations of features and applications
  • Providing a network target for SDN applications development.

The list could go on. Anyone who needs access to a test or development environment that is flexible, powerful, inexpensive, and best of all – virtual – can use VIRL. For students, it may be very difficult to find real equipment to practice on for labs and certifications. For professionals, it’s often time-consuming and error-prone to rack, wire, upgrade, and configure equipment to develop a configuration, evaluate a feature, or test an application. – assuming the the equipment is even available.

This is where VIRL can deliver significant value. It provides the ability to graphically design a network that includes virtualized instances of all Cisco Network Operating Systems – IOS, IOS XR, CSR1000, NX-OS, ASA, and other 3rd-party servers, network devices, and virtualized network functions like packet and route generators.

Once designed, VIRL provides the ability to automatically configure IP addressing and routing protocols so you can get up and running fast. Or not. Maybe you want to do it all by hand.

When you are ready, you can launch a simulation of your network and access the devices in-band or out-of-band right from your laptop. You can even extend VIRL to integrate with real live networks using data-plane connections built over physical or virtual (OVPN) connections.

Just so you know

One important thing to know about VIRL is perhaps what it does not do. The virtualized operating systems provided by VIRL include the real control- and management-plane code found in the real shipping equipment, but there is no attempt made to represent actual hardware. There are not fan-trays, or blades, or route-processors in VIRL images, and if a feature requires an ASIC for implementation – like traffic-shaping or policing – you can configure it, but the results you see will not match what you’ll see on actual hardware.

Getting and Using VIRL

VIRL is a licensed product currently available with a 20-node cap. That cap applies to Cisco network operating systems, but not other 3rd-party devices if any are included in a simulation. You can learn more about VIRL and purchase a license at Cisco’s VIRL marketplace.

VIRL is delivered as an OVA that can be deployed to Servers or PCs using VMware hypervisors, and as an ISO / UEFI image that can be deployed to bare-metal. Installing VIRL locally is straightforward but it does takes some time to download – and you have to pay attention to things like the creation of networks (physical or virtual), time-synchronization, and licensing.

Or – you could just deploy on Packet! On Packet you get VIRL on a high-performance bare-metal platform of your choice, we do the installation for you, and it’s fast – as fast as 8-10 minutes in many cases. Plus – on Packet your VIRL license is doubled to 40 nodes!

Once you’ve gotten a VIRL license come back here and keep reading. Everything you need to know to get up and running is provided below.

About VIRL on Packet

Packet offers a wide variety of bare-metal server types but only some of them are suitable for use with VIRL. First, VIRL requires an AMD64 architecture. Second, some Packet servers provide hardware that is just not applicable or used by VIRL, so there’s no need to pay for it. We recommend Type-0, Type-1, Type-1E, and Type-2 servers:

Cisco provides a resource calculator that you can use to size a system based on your needs, but in general customers use:

  • Type-0 for simulations of up to 12 nodes of IOSv. (Education)
  • Types-1/1E for larger simulations of 10 to 30 nodes including a mix of IOSv, servers, and a few of the the ‘heavier’ operating systems like IOS XRv, CSR1000v, an NX-OSv. (Small-scale professional use).
  • Type-2 for up to 40 nodes including a mix that is skewed towards the heavier operating systems. (Large-scale professional use).

Deploying VIRL on Packet

Deploying VIRL on Packet is easy using Packet's IPXE / custom-image service.  You can be up and running in minutes with a licensed, customized VIRL server using the following steps:

1. Sign Up / Login to Packet.

2. If you are a first time user, you must add a Public SSH Key which is needed in order to deploy and access the servers.

3. Create a new Project where you will then deploy the server/s.

4. Select 'Deploy New Server' from the portal menu.

\\vmware-host\Shared Folders\Desktop\Deploying VIRL on Packet_files\packet.deploy.png

5. Select your Project, 'Servers' from the offerings, and then 'Proceed'

\\vmware-host\Shared Folders\Desktop\Deploying VIRL on Packet_files\packet.project.png

6. Enter your host name.

\\vmware-host\Shared Folders\Desktop\Deploying VIRL on Packet_files\packet.project.png

7. Select your host type.  Only Types 0, 1, and 2 are supported.

\\vmware-host\Shared Folders\Desktop\Deploying VIRL on Packet_files\packet.type.png

8. Select 'Custom iPXE' for the Operating System.

\\vmware-host\Shared Folders\Desktop\Deploying VIRL on Packet_files\packet.os.png

9. Select the site to which you want to deploy. Only Sunnyvale, Amsterdam, Tokyo and Parsippany are supported at this time.

\\vmware-host\Shared Folders\Desktop\Deploying VIRL on Packet_files\packet.location.png

10. Enter '' into the iPXE URL box.

\\vmware-host\Shared Folders\Desktop\Deploying VIRL on Packet_files\packet.ipxe.png

11. Select 'Manage'

\\vmware-host\Shared Folders\Desktop\Deploying VIRL on Packet_files\packet.manage.png

12. Define your license and password settings by entering (or pasting) your 'cloud-init' YAML into the 'Add optional user data' box.

NOTE: The use of user data is completely optional.  If it is omitted your VIRL server will still deploy with default passwords and without a license.

The data used to define your passwords and license information if must be formatted as YAML and structure as follows:

  • The first line must be '#cloud-config'

  • The following keys are valid:

    • license_file: the full name of your VIRL license file.

    • license_pem: the complete PEM-key contents of your license file.

    • uwm_password: the password assigned to the 'uwmadmin' user.

    • guest_password: the password assigned to the 'guest' user.

    • virl_password: the password assigned to the 'virl' host user.

  • Multi-line values must be identified using a pipe ('|') on the key-line with the indented contents on subsequent lines.

  • Any invalid keys or data will simply be ignored and defaults used instead during deployment.

The following is an example of properly-formatted user data:

\\vmware-host\Shared Folders\Desktop\Deploying VIRL on Packet_files\packet.yaml.png

NOTE: Your user-data is not visible to anyone other than you or authorized project collaborators and is encrypted when sent to Packet.  If you're concerned about providing confidential information in this manner you can skip entering user-data and customize VIRL from the UWM once deployed.

When you've entered your user-data it should appear like the following, except with your confidential passwords and license information:

\\vmware-host\Shared Folders\Desktop\Deploying VIRL on Packet_files\packet.userdata.png

Once you have entered your user data ensure that it evaluates as '√' as indicated below, and then select 'Proceed'

\\vmware-host\Shared Folders\Desktop\Deploying VIRL on Packet_files\packet.userdataok.png


13. Select 'Deploy' to begin the deployment process.

\\vmware-host\Shared Folders\Desktop\Deploying VIRL on Packet_files\packet.go.png

14. Wait for your VIRL server to be completely deployed, then select the host name to see your server details.

\\vmware-host\Shared Folders\Desktop\Deploying VIRL on Packet_files\packet.deployed.png

15. As VIRL is deployed you will see messages regarding its state appear as 'User State' messages.

\\vmware-host\Shared Folders\Desktop\Deploying VIRL on Packet_files\packet.loading.png

If you switch to the 'Timeline' tab you can observe all of the messages that are posted during the VIRL deployment, including information about application of your passwords and license, as shown below:

\\vmware-host\Shared Folders\Desktop\Deploying VIRL on Packet_files\packet.timeline.png

16. Once VIRL is completely configured and ready for use you will see a message indicating success in the and the URL at which the VIRL UWM interface can be reached for management.

\\vmware-host\Shared Folders\Desktop\Deploying VIRL on Packet_files\packet.ready.png

17. Navigate to the UWM address and login as either ‘guest’ or ‘uwmadmin’. If you set custom passwords use these. If not, the defaults are ‘guest’, and ‘password’, respectively.

18. If you do not already have the VM Maestro client use the menu on the left to navigate to ‘VIRL Server’ and ‘Downloads’, download the appropriate version, and install it locally:

19. Open VM Maestro and connect to your Packet VIRL deployment. If you’re starting VM Maestro for the first time: 

  • Read and acknowledge the License Agreement.

  • When prompted, enter the IP address of your Packet VIRL deployment and your ‘guest’ user credentials. Once you’ve done that you should see ‘All web services are verified’:

If you already have VM Maestro installed you can create another profile to connect to your Packet VIRL deployment:

  • After VM Maestro opens select the 'Active Profile' button on the status bar:

  • Select the 'Add' button in the Web Services dialog box:

  • Enter a name for the connection profile and replace ‘localhost’ with the address of your Packet VIRL deployment, then select ‘OK’:

  • Select the 'Credentials' button:

  • Enter the ‘guest’ username and password and select 'OK’:

  • Verify that all of the web services show as ‘Compatible’:

That’s it – you’re now ready to use VIRL!

Using VIRL on Packet

There are a few more things you need to know once you’re up and running on Packet.

At Packet you are getting your own dedicated bare-metal machine that is yours alone from the time you provision your server until you actually delete the device from your account.  So even if you were to power it down, it would still accrue usage until you actually delete it from your account. 

You are responsible for ensuring that you terminate the VIRL server instance in order to avoid unexpected charges.

Issues relating to the operation of VIRL on the server should be directed to VIRL's community forum. There is no special support offering in respect to using VIRL on Packet's bare metal platform.

When using VM Maestro all of your topologies are saved locally. Nothing is kept on your VIRL server on Packet. If you tear-down your Packet server your topologies won’t be lost and you can launch the again the next time you deploy and connect to a VIRL server on Packet.

However – if you happen to customize VIRL by adding custom images these will be lost once you destroy your server on Packet. We are looking at a way to enable persistence but that is not yet available.

Finally – if you need help getting started with VIRL there are good tutorials available at the VIRL documentation site.

For more information about using VIRL on Packet you can contact Brian at or visit the Cisco VIRL community.


Deploying VIRL to Packet is easier than ever!  Once your deployment shows as ready you can use it just like you would a local VIRL server, including the use of Open VPN connectivity to access devices in your simulations directly.