Testing the ACME Topology
Now that we have created our acme.topology
MC, we can test it to see it if works as expected.
First, we can try executing it without launching any VMs.
This helps us find any syntax errors or issues with the MANIFEST
file.
To do so, we can run:
$ firewheel experiment acme.topology
You should see the following output:
$ firewheel experiment acme.topology
Do you want to execute /tmp/acme/topology/INSTALL [y/n/v/vc/q]: y
Starting to install acme.topology!
The acme.topology INSTALL file currently doesn't do anything!
Installed acme.topology!
Adding vyos-1.1.8.qc2.xz to cache. This may take a while. \ 0:00:12
Model Components Executed
┏━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━┓
┃ Model Component Name ┃ Result ┃ Timing ┃
┡━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━┩
│ misc.blank_graph │ OK │ 0.001 seconds │
│ base_objects │ OK │ 0.010 seconds │
│ generic_vm_objects │ OK │ 0.002 seconds │
│ linux.base_objects │ OK │ 0.020 seconds │
│ linux.ubuntu │ OK │ 0.018 seconds │
│ linux.ubuntu2204 │ OK │ 0.028 seconds │
│ vyos │ OK │ 0.030 seconds │
│ vyos.helium118 │ OK │ 12.123 seconds │
│ acme.topology │ OK │ 0.010 seconds │
├──────────────────────┼────────────┼────────────────┤
│ │ Total Time │ 16.283 seconds │
└──────────────────────┴────────────┴────────────────┘
Dependency resolution took 0.812 seconds
Note
We can answer y
to the question "Do you want to execute /tmp/acme/topology/INSTALL"
as this file does not perform any meaningful actions and then we will not be asked to install the MC again.
Note
If this is the first time you are running an experiment, you may see output which indicates that various image files are being cached: e.g. Adding vyos-1.1.8.qc2.xz to cache. This may take a while.
. The images are being cached for quicker access in future experiments.
If any errors are found, fix them before moving on to the next step.
Launching the Topology
Now we are ready to launch the topology. We can instantiate it with minimega by using the minimega.launch MC:
$ firewheel experiment acme.topology minimega.launch
You should see the following output:
$ firewheel experiment acme.topology minimega.launch
Model Components Executed
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━┓
┃ Model Component Name ┃ Result ┃ Timing ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━┩
│ misc.blank_graph │ OK │ 0.001 seconds │
│ base_objects │ OK │ 0.011 seconds │
│ linux.base_objects │ OK │ 0.022 seconds │
│ generic_vm_objects │ OK │ 0.001 seconds │
│ vyos │ OK │ 0.018 seconds │
│ vyos.helium118 │ OK │ 0.016 seconds │
│ linux.ubuntu │ OK │ 0.020 seconds │
│ linux.ubuntu2204 │ OK │ 0.045 seconds │
│ acme.topology │ OK │ 0.011 seconds │
│ minimega.emulated_entities │ OK │ 0.007 seconds │
│ minimega.testbed_available │ OK │ 0.026 seconds │
│ linux.ubuntu1604 │ OK │ 103.180 seconds │
│ minimega.create_mac_addresses │ OK │ 0.004 seconds │
│ minimega.resolve_vm_images │ OK │ 0.025 seconds │
│ minimega.configure_ips │ OK │ 0.002 seconds │
│ minimega.send_miniweb_arp │ OK │ 0.001 seconds │
│ minimega.schedules_ready │ OK │ 0.000 seconds │
│ vm_resource.schedule │ OK │ 0.054 seconds │
│ vm_resource.validate │ OK │ 0.015 seconds │
│ minimega.parse_experiment_graph │ OK │ 5.089 seconds │
│ minimega.launch │ OK │ 0.000 seconds │
├─────────────────────────────────┼────────────┼─────────────────┤
│ │ Total Time │ 111.348 seconds │
└─────────────────────────────────┴────────────┴─────────────────┘
Dependency resolution took 2.556 seconds
Once the topology is up and running you can use the vm mix command to check the state of the environment:
$ firewheel vm mix
VM Mix
┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━┳━━━━━━━┓
┃ VM Image ┃ Power State ┃ VM Resource State ┃ Count ┃
┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━╇━━━━━━━┩
│ ubuntu-22.04-server-amd64.qcow2 │ RUNNING │ configured │ 3 │
├──────────────────────────────────┼─────────────┼───────────────────┼───────┤
│ vyos-1.1.8.qc2 │ RUNNING │ configured │ 5 │
├──────────────────────────────────┼─────────────┼───────────────────┼───────┤
│ ubuntu-22.04-desktop-amd64.qcow2 │ RUNNING │ configuring │ 6 │
├──────────────────────────────────┼─────────────┼───────────────────┼───────┤
│ │ │ Total Scheduled │ 14 │
└──────────────────────────────────┴─────────────┴───────────────────┴───────┘
Checking Connectivity
Once all of the nodes have been configured
we can verify that the graph is connected as expected.
For this tutorial, we will use miniweb to connect to the VMs.
Please see Using miniweb for details on connecting to miniweb.
Once you are connected to miniweb, you can log into several of the VMs and verify connectivity manually via ping.
Note
We recommend that your VMs initially use simple default user names/passwords for ease of use.
For example, VMs that are Ubuntu-based might have a default username of ubuntu
and a default password of ubuntu
, while VMs that are VyOS-based might have a default username of vyos
and a default password of vyos
.
Once users are familiar with FIREWHEEL, you might choose alternate passwords for your VMs for more security.
For our experiment we at least want to verify that a VM located in Building 1 can access the data center servers prior to installation of the new access control rules.
In miniweb, you can search for building1-host-0.acme.com
and then click the connect
button to join the VNC session.
Hint
Find the IP address of one of the data center servers. (i.e., log into a server and run
ifconfig
.)Now, log into
building1-host-0.acme.com
Attempt to ping the data center IP address from our Building 1 host.
If the ping is successful, the topology has launched correctly