Just performs a yum update. Change-Id: I4cdc23a3e491c5a2f92e8beeb7eaebf2df818df3 Story: 2003305 Task: 24257
8.5 KiB
Administration
This section describes how to use kayobe to simplify post-deployment administrative tasks.
Updating Packages
It is possible to update packages on the seed and overcloud hosts. To update one or more packages:
(kayobe) $ kayobe seed host package update --packages <package1>,<package2>
(kayobe) $ kayobe overcloud host package update --packages <package1>,<package2>
To update all eligible packages, use *
, escaping if
necessary:
(kayobe) $ kayobe seed host package update --packages *
(kayobe) $ kayobe overcloud host package update --packages *
To only install updates that have been marked security related:
(kayobe) $ kayobe seed host package update --packages <packages> --security
(kayobe) $ kayobe overcloud host package update --packages <packages> --security
Note that these commands do not affect packages installed in containers, only those installed on the host.
Reconfiguring Containerised Services
When configuration is changed, it is necessary to apply these changes across the system in an automated manner. To reconfigure the overcloud, first make any changes required to the configuration on the Ansible control host. Next, run the following command:
(kayobe) $ kayobe overcloud service reconfigure
In case not all services' configuration have been modified,
performance can be improved by specifying Ansible tags to limit the
tasks run in kayobe and/or kolla-ansible's playbooks. This may require
knowledge of the inner workings of these tools but in general,
kolla-ansible tags the play used to configure each service by the name
of that service. For example: nova
, neutron
or
ironic
. Use -t
or --tags
to
specify kayobe tags and -kt
or --kolla-tags
to
specify kolla-ansible tags. For example:
(kayobe) $ kayobe overcloud service reconfigure --tags config --kolla-tags nova,ironic
Upgrading Containerised Services
Containerised control plane services may be upgraded by replacing
existing containers with new containers using updated images which have
been pulled from a registry or built locally. If using an updated
version of Kayobe or upgrading from one release of OpenStack to another,
be sure to follow the kayobe upgrade guide <upgrading>
. It may be
necessary to upgrade one or more services within a release, for example
to apply a patch or minor release.
To upgrade the containerised control plane services:
(kayobe) $ kayobe overcloud service upgrade
As for the reconfiguration command, it is possible to specify tags for Kayobe and/or kolla-ansible:
(kayobe) $ kayobe overcloud service upgrade --tags config --kolla-tags keystone
Destroying the Overcloud Services
Note
This step will destroy all containers, container images, volumes and data on the overcloud hosts.
To destroy the overcloud services:
(kayobe) $ kayobe overcloud service destroy --yes-i-really-really-mean-it
Deprovisioning The Cloud
Note
This step will power down the overcloud hosts and delete their nodes' instance state from the seed's ironic service.
To deprovision the overcloud:
(kayobe) $ kayobe overcloud deprovision
Deprovisioning The Seed VM
Note
This step will destroy the seed VM and its data volumes.
To deprovision the seed VM:
(kayobe) $ kayobe seed vm deprovision
Saving Overcloud Service Configuration
It is often useful to be able to save the configuration of the control plane services for inspection or comparison with another configuration set prior to a reconfiguration or upgrade. This command will gather and save the control plane configuration for all hosts to the Ansible control host:
(kayobe) $ kayobe overcloud service configuration save
The default location for the saved configuration is
$PWD/overcloud-config
, but this can be changed via the
output-dir
argument. To gather configuration from a
directory other than the default /etc/kolla
, use the
node-config-dir
argument.
Generating Overcloud Service Configuration
Prior to deploying, reconfiguring, or upgrading a control plane, it
may be useful to generate the configuration that will be applied,
without actually applying it to the running containers. The
configuration should typically be generated in a directory other than
the default configuration directory of /etc/kolla
, to avoid
overwriting the active configuration:
(kayobe) $ kayobe overcloud service configuration generate --node-config-dir /path/to/generated/config
The configuration will be generated remotely on the overcloud hosts
in the specified directory, with one subdirectory per container. This
command may be followed by
kayobe ovecloud service configuration save
to gather the
generated configuration to the Ansible control host.
Checking Network Connectivity
In complex networking environments it can be useful to be able to automatically check network connectivity and diagnose networking issues. To perform some simple connectivity checks:
(kayobe) $ kayobe network connectivity check
Note that this will run on the seed, seed hypervisor, and overcloud
hosts. If any of these hosts are not expected to be active (e.g. prior
to overcloud deployment), the set of target hosts may be limited using
the --limit
argument.
Baremetal Compute Node Management
When enrolling new hardware or performing maintenance, it can be useful to be able to manage many bare metal compute nodes simulteneously.
In all cases, commands are delegated to one of the controller hosts,
and executed concurrently. Note that ansible's forks
configuration option, which defaults to 5, may limit the number of nodes
configured concurrently.
By default these commands wait for the state transition to complete
for each node. This behavior can be changed by overriding the variable
baremetal_compute_wait
via
-e baremetal_compute_wait=False
Manage
A node may need to be set to the manageable
provision
state in order to perform certain management operations, or when an
enrolled node is transitioned into service. In order to manage a node,
it must be in one of these states: enroll
,
available
, cleaning
,
clean failed
, adopt failed
or
inspect failed
. To move the baremetal compute nodes to the
manageable
provision state:
(kayobe) $ kayobe baremetal compute manage
Provide
In order for nodes to be scheduled by nova, they must be
available
. To move the baremetal compute nodes from the
manageable
state to the available
provision
state:
(kayobe) $ kayobe baremetal compute provide
Inspect
Nodes must be in one of the following states:
manageable
, inspect failed
, or
available
. To trigger hardware inspection on the baremetal
compute nodes:
(kayobe) $ kayobe baremetal compute inspect
Rename
Once nodes have been discovered, it is helpful to associate them with a name to make them easier to work with. If you would like the nodes to be named according to their inventory host names, you can run the following command:
(kayobe) $ kayobe baremetal compute rename
This command will use the ipmi_address
host variable
from the inventory to map the inventory host name to the correct
node.
Running Kayobe Playbooks on Demand
In some situations it may be necessary to run an individual Kayobe
playbook. Playbooks are stored in
<kayobe repo>/ansible/*.yml
. To run an arbitrary
Kayobe playbook:
(kayobe) $ kayobe playbook run <playbook> [<playbook>]
Running Kolla-ansible Commands
To execute a kolla-ansible command:
(kayobe) $ kayobe kolla ansible run <command>
Dumping Kayobe Configuration
The Ansible configuration space is quite large, and it can be hard to
determine the final values of Ansible variables. We can use Kayobe's
configuration dump
command to view individual variables or
the variables for one or more hosts. To dump Kayobe configuration for
one or more hosts:
(kayobe) $ kayobe configuration dump
The output is a JSON-formatted object mapping hosts to their hostvars.
We can use the --var-name
argument to inspect a
particular variable or the --host
or --hosts
arguments to view a variable or variables for a specific host or set of
hosts.