Configuration¶
Hosts¶
Tenks uses Ansible inventory to manage hosts. A multi-host setup is therefore
supported, although the default hosts configuration in ansible/inventory/
will deploy an all-in-one setup on the host where the ansible-playbook
command is executed (localhost).
Configuration management of the Tenks cluster is always performed on localhost.
The
hypervisors
group should not directly contain any hosts. Its sub-groups must contain one or more system. Systems in its sub-groups will host a subset of the nodes deployed by Tenks.The
libvirt
group is a sub-group ofhypervisors
. Systems in this group will act as hypervisors using the Libvirt provider.
Variable Configuration¶
A variable override file should be created to configure Tenks. Any variables
specified in this file will take precedence over their default settings in
Tenks. This will allow you to set options as necessary for your setup, without
needing to directly modify Tenks’ variable files. An example override file can
be found in ansible/override.yml.example
.
Most of the configuration you will need to do relates to variables defined in
ansible/host_vars/localhost
. You can set your own values for these in your
override file (mentioned above). In addition to other options, you will need to
define the types of node you’d like to be able to manage as a dict in
node_types
, as well as the desired deployment specifications in specs
.
Format and guidance for available options will be found within the variable
file.
Broadly, most variables in ansible/group_vars/*
have sensible defaults
which may be left as-is unless you have a particular need to configure them. A
notable exception to this is the variable physnet_mappings
in
ansible/group_vars/hypervisors
, which should map physical network names to
the device to use for that network: this can be a network interface, or an
existing OVS or Linux bridge. If these mappings are the same for all hosts in
your hypervisors
group, you may set a single dict physnet_mappings
in
your overrides file, and this will be used for all hosts. If different mappings
are required for different hosts, you will need to individually specify them in
an inventory host_vars file: for a host with hostname myhost, set
physnet_mappings
within the file ansible/inventory/host_vars/myhost
.
Another variable that may be useful is bridge_type
. This may be either
openvswitch
(default) or linuxbridge
, and defines the type of bridges
created by Tenks. This may be different from the type of interfaces or bridges
in physnet_mappings
.
The default boot mode is UEFI. This may be changed to legacy BIOS by setting
default_boot_mode
to bios
in a variable file. The boot mode for nodes
may be set individually via ironic_config.properties.capabilities.boot_mode
in the specs
list.
Standalone Ironic¶
In standalone ironic environments, the placement service is typically not
available. To prevent Tenks from attempting to communicate with placement, set
wait_for_placement
to false
.
It is likely that a standalone ironic environment will not use authentication
to access the ironic API. In this case, it is possible to set the ironic API
URL via clouds.yaml
. For example:
---
clouds:
standalone:
auth_type: "none"
endpoint: http://localhost:6385
Then set the OS_CLOUD
environment variable to standalone
.