Many -- dare I say most -- IT certifications include content related to IP routing. How can you include an honest-to-goodness...
By submitting your personal information, you agree that TechTarget and its partners may contact you regarding relevant content, products and special offers.
router in your certification practice lab without having to invest in hundreds of dollars' worth of hardware?
Today I'm going to teach you what the VyOS router is and how you can add it to your home lab. This will give you the infrastructure necessary to practice skills such as IPv4 subnetting, DHCP traffic through router interfaces and site-to-site virtual private networks (VPNs).
Introducing the VyOS virtual router
Once upon a time, there was a free and open source virtual software router called Vyatta. Brocade Communications Systems acquired the project in 2012, closed its source code and charged money for product access.
The good news is that an independent group created a free and open source fork of Vyatta called VyOS. This was possible because Brocade still maintains a free and open source Vyatta version called Vyatta Core.
Under the hood, the VyOS router is a Linux-based network operating system that can be run from DVD or installed locally on a physical or virtual machine's hard drive. Here are a handful of VyOS's nifty features:
- Robust command-line interface that's reminiscent of other router operating systems such as Cisco's IOS;
- Scriptable environment, which means you can quickly configure VyOS virtual router instances without manually typing commands;
- Routing protocol support, including Routing Information Protocol, Open Shortest Path First and Border Gateway Protocol (BGP), which is particularly impressive when you consider that BGP is the routing protocol of the global internet; and
- Integrated security, stateful firewalling and VPN server capability.
Outlining the lab environment
Before we go any further, let me share with you what my virtual lab looks like. I use VMware Workstation as my hypervisor, but you can use Hyper-V, VirtualBox, or whichever product works for you.
Please read my related article if you need more information on how to build an IT certification practice lab. Each hypervisor has its own unique interface for deploying virtual switches, although the underlying concepts are identical.
For your reference, let me show you how I set up my VMware Workstation environment's virtual switches:
In Figure 2, I want you to see what's going on. I have two virtual networks called VMnet5 and VMnet6. I've associated the 192.168.5.0/24 network ID with VMnet5, and 192.168.6.0/24 with VMnet6.
Moreover, I connected my two VMs to their respective VMware virtual networks as shown in Figure 3.
One more thing before we get to the router configuration: make sure that within each virtual machine (VM) you configure the correct static IPv4 settings. In my lab, both VMs run Windows Server 2012 R2.
Here are my IPv4 configurations for each machine:
IPv4 address: 192.168.5.1
Subnet mask: 255.255.255.0
Default gateway: 192.168.5.1
IPv4 address: 192.168.6.1
Subnet mask: 255.255.255.0
Default gateway: 192.168.6.1
Configuring the VyOS router
Go ahead and download the VyOS ISO that's appropriate for your computer's processor architecture. Most users will be using this in a Hyper-V lab so download the ISO with amd64 in the filename.
Attach the ISO to a new VM to host the virtual router. The VyOS router has a tiny resource footprint, so you shouldn't need to assign more than 512 MB of RAM and 5 GB of hard drive space to the VM.
Now boot the VM from the VyOS disc and follow these instructions to install the operating system into the new, blank VM:
- Press ENTER to start the login process.
- Log in to the router with the username vyos and the password vyos.
- Type install image.
- Press ENTER to continue installation.
- Press ENTER to accept the default disk partition layout.
- Press ENTER to install the image on the current hard drive.
- Type yes and press ENTER to agree to wipe the VM's virtual hard disk.
- Press ENTER to accept the default virtual hard disk partition size.
- Type vyosrouter to apply that hostname to the virtual router. This can be any name you want; I'm sharing the name I chose.
- Press ENTER to accept the default boot configuration file.
- Type the administrator password again (vyos), and confirm.
- Press ENTER to install the GRUB boot loader on the default virtual hard drive.
Once the VyOS installation completes, eject the VyOS virtual DVD and type reboot now to restart the virtual router.
Now comes the challenging part -- assigning static IPv4 addresses to the appropriate network interfaces. Type show interfaces detail to figure out which of your two virtual network interfaces (eth0 and eth1) has which media access control (MAC) hardware address.
You'll then cross-reference those MAC addresses with each virtual network interface card (NIC) defined in the VM properties. My VyOS router, for instance, had the following interface linkage:
eth0 => VMnet5
eth1 => VMnet6
If you've ever performed router configuration before, then you know that in most cases you need to enter a dedicated configuration mode. Here's the code I used to assign each virtual NIC a static IP:
set interfaces ethernet eth0 address 192.168.5.1/24
set interfaces ethernet eth1 address 192.168.6.1/24
Don't forget about the commit and save commands. If you leave those off, then you'll lose your carefully typed configuration. Reboot the virtual router to ensure the settings persist after restarting the virtual device.
Run the show interfaces command and verify that your interfaces have static IP addresses.
Let's finish up by testing our new network topology.
Test your new routed internetwork
I suggest temporarily disabling Windows Firewall on your VMs for the duration of this test. From my dc1.company.pri virtual machine, I'll open an administrative PowerShell or command prompt session and run the following sequence of ping commands:
ping 192.168.5.10 (tests local machine connectivity)
ping 192.168.5.1 (tests connectivity to router's "near side" interface)
ping 192.168.6.1 (tests connectivity to router's "far side" interface)
ping 192.168.6.10 (tests connectivity with mem1, the remote host)
I hope you found this tutorial helpful. This new setup will doubtless allow you to broaden and deepen your networking skills. Happy studying!
Build a virtual training lab for IT staff
How Windows admins can get started with Linux
Why virtual routers are becoming more common