Available CLI Helpers
Helpers allow the extension of the CLI with new “commands”. They are invoked by name (the most common option) or using the run command. The name of the file defining a Helper is used as the name of that Helper. Helpers available in the current CLI session can be enumerated using the list command.
Below are all the available Helpers within FIREWHEEL. To learn more about Helpers see Helpers.
example_helpers pytest
Use this file as a template for new Python Helpers. If you retain the sections (and just update the content) then the Helper should execute properly.
Arguments
When executed, this Helper will print out any passed in arguments.
Examples
firewheel example_helpers pytest
example_helpers subgroup
This is an example of an index file. If no sub-Helper is called, the Helper group’s index file is automatically called. Use this file as a template for new index Helpers. If you retain the sections (and just update the content) then the index Helper should execute properly.
Arguments
N/A
Examples
firewheel example_helpers subgroup
example_helpers subgroup test
Use this file as a template for new Helpers. If you retain the sections (and just update the content) then the Helper should execute properly.
Arguments
N/A
Examples
firewheel example_helpers subgroup test
example_helpers test
Use this file as a template for new Helpers. If you retain the sections (and just update the content) then the Helper should execute properly.
Arguments
N/A
Examples
firewheel example_helpers test
experiment
Create a FIREWHEEL experiment using a set of model components.
Usage: firewheel experiment [-h] [--profile] [--dry-run] [-f] <model_component>[:<name1>=<value1>[:<name2>=<value2>]...] [<model_component2>[:<name1>=<value1>[:<name2>=<value2>]...]]
All of the experiment Helper’s command line arguments, along with any named MC parameter value settings, must be included on a single line.
Named parameter value settings are passed into the model component’s plugin.
If no name is provided, these arguments are treated as positional. Plugin
arguments are separated from both the model component and additional arguments
by a colon (:). (i.e. <mc>:<name1>=<value1>:<name2>=<value2>
or a combination
of positional and named arguments <mc>:<value1>:<value2>:<named1>=<value3>
).
No spaces are allowed.
The ordering of model components on the command line provides an explicit
“depends” relationship among them. For example, firewheel experiment mc1 mc2
implies that mc2 will run after mc1.
For most experiments, users will want at least two model components: their
topology and some method of “doing something” with the topology. This could
include anything from exporting the topology (with the print_graph
Model
Component) or realizing the topology into an emulation. The current method to
launch an experiment is to use the minimega.launch
model component which uses
minimega to instantiate the emulation. NOTE: This is not required.
FIREWHEEL is extensible and enables users to create other experiment instantiation methods.
Arguments
Positional Arguments
- <model_component[:<value1>[:<param2>=<value2>]]>
The model component to use in the experiment. More than one of these may be specified. (required)
If the given Model Component’s Plugin requires a parameter, the value can be passed to the MC by using a colon separated list (e.g.
<model_component>:[value1]:[value2]
). Keyword parameters can be specified as well, using the traditional keyword format ofname=value
. If no name is provided, these arguments are treated as positional. No spaces are allowed when providing MC parameters.Command-line examples:
$ # Single MC positional argument $ firewheel experiment tests.router_tree:3 minimega.launch $ # Muliple MC named arguments $ firewheel experiment tests.router_tree:3 tests.large_resource:size=1024:location_dir=/tmp:preload=True minimega.launch
Named Arguments
- -h, --help
Print this experiment Helper description then exit. (optional)
- -f, --force
Force the experiment to launch even if there is an existing experiment. This essentially clears the testbed by running
firewheel restart
. (optional)
- -r, --restart
Similar to
-f
, but only restarts if an active experiment is detected. If an experiment is detected, runsfirewheel restart
before starting the experiment. (optional)
- --profile
Output profiling info for experiment graph construction. It creates a
firewheel_profile.prof
file in the current working directory. (optional)
- --dry-run
Output the ModelComponent sequence that would be evaluated, but don’t actually evaluate the components. (optional)
- -ni, --no-install
Continue regardless of if Model Components within the experiment have been “installed” (i.e., the
INSTALL
file executed). Defaults to None. (optional)
Examples
firewheel experiment acme.run minimega.launch
firewheel experiment tests.vm_gen:3 minimega.launch
firewheel experiment tests.vm_gen:size=3 minimega.launch
firewheel experiment -r tests.vm_gen:size=3 tests.connect_all tests.ping_all minimega.launch
mc dep_graph
Print out a Graphviz dependency graph between all model components in currently installed repositories.
Arguments
All arguments are optional.
Named Arguments
- -h, --help
Show a help message and exit
- -o
Output file name to print to. Print to
stdout
if not provided.
Example
firewheel mc dep_graph
firewheel mc dep_graph -o /tmp/test.txt
mc generate
This Helper is used to generate a new model component.
It can be used in “interactive” mode or via CLI arguments.
Ultimately, it calls firewheel.control.utils.new_model_component
.
Usage: firewheel mc generate [-h] --name NAME --location LOCATION [--attribute_depends ATTRIBUTE_DEPENDS [ATTRIBUTE_DEPENDS ...]] [--attribute_provides ATTRIBUTE_PROVIDES [ATTRIBUTE_PROVIDES ...]] [--attribute_precedes ATTRIBUTE_PRECEDES [ATTRIBUTE_PRECEDES ...]] [--model_component_depends MODEL_COMPONENT_DEPENDS [MODEL_COMPONENT_DEPENDS ...]] [--model_component_precedes MODEL_COMPONENT_PRECEDES [MODEL_COMPONENT_PRECEDES ...]] [--plugin PLUGIN] [--model_component_objects MODEL_COMPONENT_OBJECTS] [--plugin_class PLUGIN_CLASS] [--vm_resource VM_RESOURCES [VM_RESOURCES ...]] [--image IMAGE] [--arch ARCH] [--non-interactive] [--template_dir TEMPLATE_DIR] [--no_templates]
Arguments
Named Arguments
MANIFEST-related Arguments:
- --name <NAME>
The Model Component name.
- --attribute_depends <ATTRIBUTE_DEPENDS [ATTRIBUTE_DEPENDS ...]>
Graph Attribute(s) depended on by the new Model Component as space-separated-strings.
- --attribute_provides <ATTRIBUTE_PROVIDES [ATTRIBUTE_PROVIDES ...]>
Graph Attribute(s) provided by the new Model Component as space-separated-strings.
- --attribute_precedes <ATTRIBUTE_PRECEDES [ATTRIBUTE_PRECEDES ...]>
Graph Attribute(s) preceded by the new Model Component as space-separated-strings.
- --model_component_depends <MC_DEPENDS [MC_DEPENDS ...]>
Model Component names required by the new MC. These should be space-separated-strings.
- --model_component_precedes <MC_PRECEDES [MC_PRECEDES ...]>
Model Component names that will be preceded by the new MC. These should be space-separated-strings.
- --plugin <PLUGIN>
File name for a Plugin. If this is needed, we recommend using
plugin.py
.
- --model_component_objects <MODEL_COMPONENT_OBJECTS>
File name for Model Component Objects file. If this is needed, we recommend using
model_component_objects.py
.
- --location <LOCATION>
Location for the new Model Component (i.e Where should the newly generated MC files go?). Include the directory of the MC itself. That is, if you would like the new MC to be placed in
/opt/firewheel/model_components/
your location should be/opt/firewheel/model_components/<MC dir name>
.
- --plugin_class <PLUGIN_CLASS>
Name for the new Plugin class.
- --vm_resource <VM_RESOURCES [VM_RESOURCES ...]>
File(s) to be used as VM Resources as space-separated-strings.
- --image <IMAGE>
Specify a file to be used as a VM disk.
- --arch <ARCH>
Specify the architecture of the supplied image (x86_64, x86, etc). Defaults to
x86_64
if an image is provided but the--arch
option is not.
Configuration-related Arguments:
- --non-interactive
Require minimum parameters as arguments and do not prompt for any values
- --no_templates
Do not generate files from templates. Only generate a MANIFEST file.
- --template_dir <TEMPLATE_DIR>
Override the configured templates directory.
mc list
List information about the currently installed model components.
Model components can be grouped by repository (default), or any of the provides
, depends
, precedes
, model_component_depends
, model_component_precedes
.
fields in the model component’s manifest.
Filters can be used to reduce the MCs that are shown. Filters are independent and
are greedily matching. If multiple filters are used then anything that matches all
filters will be displayed. Filters will attempt substring matching so ensure that
you provide enough of a substring to the filter to narrow down the displayed results.
Arguments
All arguments are optional.
Named Arguments
- -h, --help
Show a help message and exit.
- --paths, -p
Print additional paths information.
- -g <group>, --group <group>
- Default:
repository
Group model components by one of:
repository
,provides
,depends
,model_component_depends
.
- -m
Print without color, i.e. monochromatic.
- -k <FIELDS [FIELDS ...]>
Space separated list of additional MANIFEST fields to display for each found MC, in the form field[=filter] where filter is an optional substring of the results being filtered on. Example fields are in the following table, but any manifest fields should be valid.
Filter fields
Description
name
The name of the MC.
provides
The attributes provided by the MC.
depends
The attributes depended on by the MC.
precedes
The attributes preceded by the MC.
attributes
The dictionary of both provides and depends. Filters provided return true if found in either provides or depends.
model_component_depends
The model components depended on by the MC.
model_component_precedes
The model components preceded by the MC.
model_component_objects
The model_component_objects provided by the MC.
vm_resources
The VM Resources proved by the MC. This will not auto-expand any wildcards (e.g.
vm_resources/**
).
Examples
firewheel mc list -p
firewheel mc list -p -m -k provides=topology
firewheel mc list -p -g provides -k name=ubuntu
firewheel mc list -k vm_resources
mm clean_bridge
In the rare case that when minimega is shut down it does not clean up all of its Open vSwitch interfaces, these interfaces should then be removed.
This Helper will enable a user to manually remove all interfaces created by minimega and restore the control_bridge
to the original state (prior the experiment running).
When run, this Helper identifies the control_bridge
, finds all ports which start with the phrase mega_tap
, and then removes them via both the ovs-vsctl
and ip link
commands.
See also
For more information on the control_bridge
see minimega.
Warning
Do not run this Helper while your experiment is running! It will have unintended consequences!
Arguments
This Helper takes no arguments.
Example
firewheel mm clean_bridge
mm clear_cache
This will delete all files in the requested FileStore
.
Usage: firewheel mm clear_caches <caches>
Arguments
A user must either provide a list of caches (one of images
, schedules
, vm_resources
) or the mm clear_cache --all
parameter.
Named Arguments
- -h, --help
Show help message and exit.
- --all
Clear all caches, including
images
,schedules
, andvm_resources
Positional Arguments
- <caches>
The name(s) of the caches to clear (i.e.
images
,schedules
, and/orvm_resources
).
Example
firewheel mm clear_cache images
firewheel mm clear_cache images schedules
firewheel mm clear_cache --all
mm flush_locks
This will delete all lock directories and optionally the associated cache_files in the requested FileStore
.
Usage: firewheel mm flush_locks <caches>
Arguments
A user must either provide a list of caches (one of images
, schedules
, vm_resources
) or the mm flush_locks --all
parameter.
Named Arguments
- -h, --help
Show help message and exit.
- --all
Clear lock files for all caches, including
images
,schedules
, andvm_resources
.
- --clear
Clear cache files associated with found lock files.
Positional Arguments
- <caches>
The name(s) of the caches to check (i.e.
images
,schedules
, and/orvm_resources
).
Example
firewheel mm flush_locks images
firewheel mm flush_locks --clear images schedules
firewheel mm flush_locks --all
mm make_bridge
If the experiment interface is the loopback interface (single node installation), the cluster is configured to use GRE tunnels, or the mega_bridge interface already exists, this Helper does nothing.
Otherwise, the following steps occur:
An Open vSwitch bridge is created for the mega_bridge
A port is added between the mega_bridge and the experiment interface
The experiment interface has its IP flushed.
The previous experiment interface IP address is added to the mega_bridge.
mm mesh
Attempts to run mesh dial from the head node to all compute nodes. This command blocks until the expected degree of the cluster matches what is reported by minimega on the head node. Takes one optional argument, when equal to quiet, limits debug output.
Usage: firewheel mm mesh [quiet]
Arguments
All arguments are optional.
Positional Arguments
- quiet
Do not print debug information.
Example
firewheel mm mesh
firewheel mm mesh quiet
mm show_caches
List the image and vm_resource cache directories which are found in the
FileStore
. This enables
users to identify if a file was correctly cached.
Examples
firewheel mm show_caches
pull file
Pull a file or directory from a VM using the VM resource handler. This does not require that the VM is running a SSH server. Also, unlike scp, there is no need to use the control_network model component since the VM resource handler has access to the VM through a serial port.
All files get placed at the location specified on the command line.
Usage: firewheel pull file [-h] <filename> <vm hostname> <destination>
Arguments
Named Arguments
- -h, --help
Show help message and exit.
- --attempts
- Default:
24
Number of 5 second attempts to try before giving up
Positional Arguments
- <filename>
The name of the file or directory on the VM to extract
- <vm hostname>
The hostname of the VM within the experiment from which to pull the files
- <destination>
Local destination path for the files that were extracted from the VM
Example
firewheel pull file /tmp/test.txt host.root.net /tmp/myfile.txt
firewheel pull file /tmp/test host.root.net /tmp/mydir
push file
Push a file to a VM using the VM resource handler. This does not require that the VM is running a SSH server. Also, unlike scp, there is no need to use the control_network model component since the VM resource handler has access to the VM through a serial port.
All files get placed at the location specified on the command line.
Note
The destination MUST be the full path (including the filename), not simply a destination directory.
Warning
Any shell expansions (e.g. ~
) used in the destination
path are resolved BEFORE the file is pushed to the VM.
Usage: firewheel push file [-h] <filename> <vm hostname> <destination>
Arguments
Named Arguments
- -h, --help
Show this help message and exit
Positional Arguments
- <filename>
The name of the file to push to the VM
- <vm hostname>
The hostname of the VM to push the file to.
- <destination>
The full path (including the filename) of the destination location on the VM for the file.
Example
firewheel push file /tmp/test.txt host.root.net /tmp/myfile.txt
firewheel push file /tmp/test.txt whost.root.net '/Users/User/Downloads/myfile.txt'
repository install
Install a new repository of Model Components. The repository should be an existing directory on the filesystem. The path may be specified absolute or relative. If the path does not exist, an error message is printed.
Some Model Components may provide an additional install script called INSTALL
which can be executed to perform other setup steps (e.g. installing an extra python package or downloading an external VM resource).
INSTALL scripts can be can be any executable file type as defined by a shebang line.
Warning
The execution of Model Component INSTALL
scripts can be a DANGEROUS operation. Please ensure that you fully trust the repository developer prior to executing these scripts.
See also
See Model Component INSTALL file for more information on INSTALL scripts.
When installing a Model Component, users will have a variety of choices to select:
y
- yes, install execute this scriptn
- no, do not execute this scriptv
- view, see the script textvc
- view color, see the script text with color support, must use a system pager which supports this behavior (e.g.PAGER='less -R'
)q
- quit, exit immediately
Arguments
- path
The path to the repository to install. If not provided, will assume that the user desires to run the installation scripts for all existing repositories (assuming the
-s
flag is also used).
- -s, --script
Run any Model Component-specific installation scripts. The install script should be in the Model Components top-level directory in a file called
INSTALL
.
- -i, --insecure
Automatically run all Model Component INSTALL scripts. Must be run with the
repository install -s
option to take effect.
- -h, --help
Show a help message and exit.
Examples
firewheel repository install <directory>
firewheel repository install --script <directory>
repository list
Show all installed repositories.
Example
firewheel repository list
repository uninstall
Uninstall a repository of model components. The repository should be an existing directory on the filesystem. The path may be specified absolute or relative.
Warning
This does NOT uninstall any actions performed by Model Component INSTALL
scripts.
Example
firewheel repository uninstall <directory>
restart experiment
Cleans up all of the virtual machines and virtual networks started by FIREWHEEL and ensures it is ready for another run.
restart hard
Executes the stop hard and start Helpers in order to restart the FIREWHEEL system. This will tear down all services, virtual machines, and networking independent of whether FIREWHEEL restart them or not. Use this if a bug in FIREWHEEL is preventing a regular restart from working.
Example
firewheel restart hard
restart
Cleans up all of the virtual machines and virtual networks started by
FIREWHEEL and ensures it is ready for another run. This is the same
as running firewheel restart experiment
Example
firewheel restart
scp
SCP files to or from a VM that is currently running in the FIREWHEEL environment. All SCP options can be used.
Warning
- To use this, the following requirements MUST be met:
The VM must be running an SSH server.
The experiment must be run with the control_network model component. For example:
firewheel experiment tests.vm_gen:2 control_network minimega.launch
.This Helper MUST be run from the cluster head node.
If any of these conditions are not or cannot be met, use the
pull file Helper (i.e. firewheel file pull
) instead.
Arguments
Named Arguments
- -h, --help
Show help message and exit.
Positional Arguments
- <SCP command>
The remaining standard SCP options, which includes the the hostname of the VM to SCP to or from. An optional username can be specified before the hostname as well. (i.e. ubuntu@vm.net)
Example
firewheel scp ubuntu@host.root.net:/tmp/test.txt /tmp/myfile.txt
firewheel scp -r ubuntu@host.root.net:/tmp/test /tmp/mydir
firewheel scp /tmp/test.txt ubuntu@host.root.net:/tmp/test.txt
ssh
SSH to VM that is currently running in the FIREWHEEL environment. This command supports running commands directly from a call to SSH.
Warning
- To use this, the following requirements MUST be met:
The VM must be running an SSH server.
The experiment must be run with the control_network model component. For example:
firewheel experiment tests.vm_gen:2 control_network minimega.launch
.This Helper MUST be run from the cluster head node.
Arguments
Named Arguments
- -h, --help
Show help message and exit.
Positional Arguments
- <SSH options>
The remaining standard SSH options, which includes the the hostname of the VM to SSH to. An optional username can be specified before the hostname as well. (i.e. ubuntu@vm.net).
Example
firewheel ssh ubuntu@host.root.net
firewheel ssh vyos@bgp.root.net
firewheel ssh ubuntu@vm.net touch /tmp/test
start
Start the FIREWHEEL services (grpc and discovery) and set up the minimega environment.
status
This informs a user if the testbed is available for use or occupied by an existing experiment.
Example
firewheel status
stop hard
- Aggressively clean up FIREWHEEL after an experiment. This will:
Destroy all running VMs (regardless of whether FIREWHEEL/minimega created them).
Restart all FIREWHEEL/minimega services
Recreate minimega’s mesh
Kill all
vm_resource_handler
processesSet permissions on the
mm_base
directory (typically/tmp/minimega
)Remove all logs
It is important to note that this will destroy all virtual machines found on the system and likely any networking that is not “standard”. Only use this if you want to clear the system independent of what FIREWHEEL’s state thinks it is.
It is almost always better to use stop instead.
Example
firewheel stop hard
stop
This will request all FIREWHEEL services to stop and kill all
vm_resource_handler
processes.
This will not aggressively tear down everything. Use firewheel stop hard
for that.
Example
firewheel stop
test all
- Executes all of the Helpers in the test folder including:
test unit
test functional all
Example
firewheel test all
test functional
Run functional (i.e. end-to-end) test cases based on the input suite (minimal, basic, windows, or all). It is
important to note that suite=all
does NOT include windows test cases. In order
to run suite=windows
users must have the windows model component repository installed and all
images downloaded.
Usage: firewheel test functional [-h] [suite]
Arguments
All arguments are optional.
Positional Arguments
- <suite>
- Default:
basic
Which test suite should be run. This is one of (
all
,minimal
,windows
,basic
).
Named Arguments
- -h, --help
Show help message and exit.
Example
firewheel test functional
firewheel test functional all
test
- Executes all of the Helpers in the test folder including:
test unit
test functional minimal
This Helper is extremely valuable to test if a FIREWHEEL install is successful.
Example
firewheel test
test unit
Run all available unit test cases using pytest
. Any extra arguments
given to the helper will be passed to the pytest
runner.
Example
firewheel test unit
time
Get the time (in UTC) of when the experiment will start
(i.e. when experiment positive time will start). To get the
time in UTC on your control/compute nodes (to compare) you can
use the command date --utc
.
If the experiment has started, the number of seconds since the experiment started is also printed.
Arguments
All arguments are optional.
Named Arguments
- -h, --help
Show help message and exit.
- --json
Dump output as JSON-formatted dictionary in the form of
{start_time: <datetime>, seconds_since_start: <int>}
Example
firewheel time
firewheel time --json
tmux cluster
Uses the compute lists to build tmux for the cluster. To join this tmux session
use the command: tmux -S /tmp/cluster attach
.
Example
firewheel tmux cluster
tmux -S /tmp/cluster attach
tshoot check_nics
Check to see if the physical host control bridge is in a sane state. This includes ensuring that the control bridge is up (but doesn’t necessarily have an IP address).
Example
firewheel tshoot network check_nics
tshoot diskspace
Troubleshoot possible issues with disk space. This Helper will inform a user if the disks are too full to run an experiment.
tshoot
This Helper troubleshoots various issues that can arise with FIREWHEEL deployments. This will execute ALL troubleshooting Helpers to assist in identifying potential problems. This Helper is also useful to run after an installation is complete.
Example
firewheel tshoot
tshoot mtu
This Helper finds possible problems with MTU sizes. FIREWHEEL and minimega strongly recommend that Jumbo Frames are turned on. This feature enables packets with large MTUs (such as those needing to use GRE tunnels) to traverse the network. Therefore, we use this Helper to verify that Jumbo Frames (9000 MTU) are turned on.
Example
firewheel tshoot network mtu
vm builder
This Helper enables users to launch/modify a single VM based on a passed in image file using minimega. It is largely useful for preparing images for use with FIREWHEEL and as a testing ground for developing VM resources using the exact OS.
This helper relies on libvirt to provide automated networking to VMs, therefore, this is installed if it is not already.
Warning
Currently, the automated installation of libvirt only works on Debian-based systems (e.g. Ubuntu).
If users would like to use libvirt networking, via the -n
flag, than that interface is automatically bridged to the host system.
Within the VM, users will likely have to run sudo dhclient
to ensure that their interfaces receive an IP address.
However, after this point, the VM should have network access.
Note
Users with corporate security features (e.g. proxies, firewalls, etc.) may need to manually configure the VM services to access the network.
Ultimately, it calls firewheel.control.utils.vm_builder
and if desired, users can call that script manually.
Usage: firewheel vm builder [-h] (--modify | --launch) [-n] [-m MEMORY] [-c VCPUS] [-d CDROM] image
Arguments
Users must provide a KVM-compatible image file and either --modify
or --launch
.
Positional Arguments
- image
VM image file to work with. Must be KVM-compatible.
Named Arguments
- -h, --help
Show a help message and exit.
- --modify
Launch a VM image and save the changes.
- --launch
Launch a VM image, discarding the changes on shutdown.
- -n, --network
Include a network interface when launching the VM.
- -m, --memory
- Default:
2048
Memory allotted to the VM [MB].
- -c, --vcpus
- Default:
1
Number of VCPUs allotted to the VM.
- -d, --cdrom
Include a CD-ROM ISO image when launching a VM. May be specified multiple times.
Example
# Modify an image and provide 4096MB of memory
firewheel vm builder --modify -n -m 4096 /path/to/image.qcow2``
# Launch (i.e. don't persist changes) an image with more VCPUs
firewheel vm builder --launch -n -c 4 /path/to/image.qcow2``
# Modify an image and pass in a CD
firewheel vm builder --modify -n --cdrom /path/to/cd.iso /path/to/image.qcow2``
vm list
List running state information about the currently deployed virtual machines. Filters can be used to reduce the VMs that are shown. Filters result in the union of all filters. If multiple filters are used then anything that matches all of filters will be displayed. Filters will attempt substring matching so ensure that you provide enough of a substring to the filter to narrow down the displayed results.
Arguments
All arguments are optional.
Named Arguments
- -h, --help
Show help message and exit.
- --csv
Output in CSV format.
Positional Arguments
- <field[=filter]>
A field to display for each found VM, in the form field[=filter] where filter is a substring of the results being filtered on. Available fields are in the following table.
Filter fields
Description
uuid
Unique number for each VM instance
name
The name of the VM
state
State of VM QEMU process and vm_resource run status
image
Full name of the base image of the VM
hostname
The hostname as it was assigned in the experiment
vnc
The shortened port number used to connect to the VM through VNC. Note, the real port number is 5900 + that shown
time
If VM is configuring, this displays the time of the vm_resource currently running within a VM. If VM has not started configuring, this displays N/A. If VM is configured, this displays 0, unless an experiment start time has been determined, in which case all VMs return :)
ip
The VMs control_network IP address, if the experiment included the control_network MC
Example
firewheel vm list vnc hostname image
firewheel vm list name=host.root.net vnc hostname
firewheel vm list name=root image=vyos vnc hostname
firewheel vm list name=root --csv
firewheel vm list image=vyos state
vm log
Retrieve a log for the given VM. This enables users to easily access log files for VMs without intimate knowledge of where the VM resource logs are stored. Additionally, it enables easy parsing and data analysis of logs.
All log output is directly piped to standard out and can be further examined using common
command line tools such as less
, tail
, or grep
, just to name a few.
Arguments
Named Arguments
- -h, --help
Show help message and exit.
- -j, --json
Retrieve the JSON log rather than the standard log.
Positional Arguments
- <vm>
The name of the VM for which the log should be retrieved.
Example
firewheel vm log host.root.net
firewheel vm log --json host.root.net
firewheel vm log host.root.net | less
vm mix
Generates a table showing the VM Images for a running experiment. The table also includes the power state of the VMs and the vm_resource state. Images that are the same and have the same power/vm_resource state are grouped. The count of the various VMs are provided. Additionally, the total number of scheduled VMs is shown at the bottom of the table.
Example
firewheel vm mix
The output will look similar to the below table.:
+------------------------------------------------+-------------+----------------------+-------+
| VM Image | Power State | VM Resource State | Count |
+================================================+=============+======================+=======+
| ubuntu-16.04.4-server-amd64.qcow2 | RUNNING | configured | 4 |
+------------------------------------------------+-------------+----------------------+-------+
+------------------------------------------------+-------------+----------------------+-------+
| | | Total Scheduled | 4 |
+------------------------------------------------+-------------+----------------------+-------+
vm resume
Submit a RESUME
event to a set of VMs within an experiment. This can be applied to a set of
VMs or to all VMs within the experiment. This is primarily used for resuming VMs which have
created a break within the VM resource schedule. For more information see VM Resource Schedule.
Usage: firewheel vm resume [-h] (-a | vm_name [vm_name ...])
Arguments
Named Arguments
- -h, --help
Show help message and exit.
Positional Arguments
- <vm_name>
The hostname of the VM within the experiment whose schedule should resume.
Example
firewheel vm resume host.root.net
firewheel vm resume host.root.net bgp.root.net
firewheel vm resume --all