Provided by: masakari-common_19.0.0-0ubuntu1_all 
      
    
NAME
       masakari - masakari 19.0.0
       Masakari  is an OpenStack project designed to ensure high availability of instances and compute processes
       running on hosts.
       This documentation is intended to help explain the  current  scope  of  the  Masakari  project  and   the
       architectural  decisions  made  to  support  this  scope.   The  documentation  will  include  the future
       architectural roadmap and  the current development process and policies.
MASAKARI API REFERENCES
       The Masakari API is extensive. We provide a concept guide which gives some of the high level details,  as
       well as a more detailed API reference.
OPERATOR GUIDE
   Architecture Overview
       • Masakari architecture: An overview of how all the components in masakari work together.
   Installation
       A detailed install guide for masakari.
   Masakari services
   Masakari service overview
       Masakari  provides  Virtual  Machines High Availability(VMHA), and rescues KVM-based Virtual Machines(VM)
       from a failure events described below:
       • VM process down - restart vm (use nova stop API, and nova start API).   Libvirt  events  will  be  also
         emitted by other failures.
       • Provisioning  process  down - restarts process, changes nova-compute service status to maintenance mode
         (use nova service-disable).
       • nova-compute host failure - evacuate all the VMs from failure host according to the following  recovery
         methods (use nova evacuate API).
         • auto - evacuate all the VMs with no destination node for nova scheduler.
         • reserved_host - evacuate all the VMs with reserved hosts as the destination nodes for nova scheduler.
         • auto_priority  -  evacuate  all the VMs by using auto recovery method firstly.  If failed, then using
           reserved_host recovery method.
         • rh_priority - evacuate all the VMs by using reserved_host recovery method firstly.  If  failed,  then
           using auto recovery method.
       The below services enables deplores to integrate with the Masakari directly or through custom plug-ins.
       The Masakari service consists of the following components:
       masakari-api
              An  OpenStack-native  REST  API that processes API requests by sending them to the masakari-engine
              over Remote Procedure Call (RPC).
       masakari-engine
              Processes the notifications received from masakari-api  by  executing  the  recovery  workflow  in
              asynchronous way.
   Install and configure
       This section describes how to install and configure Masakari services on the compute node.
       This  section assumes that you already have a working OpenStack environment with the following components
       installed: Nova, Glance, Cinder, Neutron and Identity.
       The installation and configuration vary by distribution.
   Install and configure for Ubuntu
       This section describes how to install and configure Masakari for Ubuntu 18.04 (bionic).
   Prerequisites
       Before you install and configure the masakari service, you must create  databases,  service  credentials,
       and API endpoints.
       1. To create the masakari database, follow these steps:
          • Use the database access client to connect to the database server as the root user:
                # mysql
          • Create the masakari database:
                mysql> CREATE DATABASE masakari CHARACTER SET utf8;
          • Grant access privileges to the databases:
                mysql> GRANT ALL PRIVILEGES ON masakari.* TO 'username'@'localhost' \
                  IDENTIFIED BY 'MASAKARI_DBPASS';
                mysql> GRANT ALL PRIVILEGES ON masakari.* TO 'username'@'%' \
                  IDENTIFIED BY 'MASAKARI_DBPASS';
             Replace MASAKARI_DBPASS with a suitable password.
          • Exit the database access client.
       2. Source the admin credentials to gain access to admin-only CLI commands:
             $ . admin-openrc
       3. Create the Masakari service credentials:
          • Create the masakari user with password as masakari:
                $ openstack user create --password-prompt masakari
                User Password:
                Repeat User Password:
                +---------------------+----------------------------------+
                | Field               | Value                            |
                +---------------------+----------------------------------+
                | domain_id           | default                          |
                | enabled             | True                             |
                | id                  | 8a7dbf5279404537b1c7b86c033620fe |
                | name                | masakari                             |
                | options             | {}                               |
                | password_expires_at | None                             |
                +---------------------+----------------------------------+
          • Add the admin role to the masakari user:
                $ openstack role add --project service --user masakari admin
          • Create the masakari service entity:
                $ openstack service create --name masakari \
                --description "masakari high availability" instance-ha
                +-------------+----------------------------------+
                | Field       | Value                            |
                +-------------+----------------------------------+
                | description | masakari high availability       |
                | enabled     | True                             |
                | id          | 060d59eac51b4594815603d75a00aba2 |
                | name        | masakari                         |
                | type        | instance-ha                      |
                +-------------+----------------------------------+
       4. Create the Masakari API service endpoints:
             $ openstack endpoint create --region RegionOne \
               masakari public http://<CONTROLLER_IP>/instance-ha/v1/$\(tenant_id\)s
             +--------------+-------------------------------------------------------+
             | Field        | Value                                                 |
             +--------------+-------------------------------------------------------+
             | enabled      | True                                                  |
             | id           | 38f7af91666a47cfb97b4dc790b94424                      |
             | interface    | public                                                 |
             | region       | RegionOne                                             |
             | region_id    | RegionOne                                             |
             | service_id   | 060d59eac51b4594815603d75a00aba2                      |
             | service_name | masakari                                              |
             | service_type | instance-ha                                           |
             | url          | http://<CONTROLLER_IP>/instance-ha/v1/$(tenant_id)s   |
             +--------------+-------------------------------------------------------+
             $ openstack endpoint create --region RegionOne \
               masakari internal http://<CONTROLLER_IP>/instance-ha/v1/$\(tenant_id\)s
             +--------------+-------------------------------------------------------+
             | Field        | Value                                                 |
             +--------------+-------------------------------------------------------+
             | enabled      | True                                                  |
             | id           | 38f7af91666a47cfb97b4dc790b94424                      |
             | interface    | internal                                              |
             | region       | RegionOne                                             |
             | region_id    | RegionOne                                             |
             | service_id   | 060d59eac51b4594815603d75a00aba2                      |
             | service_name | masakari                                              |
             | service_type | instance-ha                                           |
             | url          | http://<CONTROLLER_IP>/instance-ha/v1/$(tenant_id)s   |
             +--------------+-------------------------------------------------------+
             $ openstack endpoint create --region RegionOne \
               masakari admin http://<CONTROLLER_IP>/instance-ha/v1/$\(tenant_id\)s
             +--------------+-------------------------------------------------------+
             | Field        | Value                                                 |
             +--------------+-------------------------------------------------------+
             | enabled      | True                                                  |
             | id           | 38f7af91666a47cfb97b4dc790b94424                      |
             | interface    | admin                                                 |
             | region       | RegionOne                                             |
             | region_id    | RegionOne                                             |
             | service_id   | 060d59eac51b4594815603d75a00aba2                      |
             | service_name | masakari                                              |
             | service_type | instance-ha                                           |
             | url          | http://<CONTROLLER_IP>/instance-ha/v1/$(tenant_id)s   |
             +--------------+-------------------------------------------------------+
   Install and configure Masakari
       NOTE:
          • You must install Masakari on the Controller Nodes only.
       1. Clone masakari using:
             # git clone https://opendev.org/openstack/masakari.git
       2. Prepare the masakari configuration files:
          1. Generate via tox:
             Go  to /opt/stack/masakari and execute the command below.  This will generate masakari.conf.sample,
             a sample configuration file, at /opt/stack/masakari/etc/masakari/:
                # tox -egenconfig
          2. Download from:
             # masakari.conf.sample
          3. Rename masakari.conf.sample file to masakari.conf, and edit sections as shown below:
                [DEFAULT]
                transport_url = rabbit://stackrabbit:admin@<CONTROLLER_IP>:5672/
                graceful_shutdown_timeout = 5
                os_privileged_user_tenant = service
                os_privileged_user_password = admin
                os_privileged_user_auth_url = http://<CONTROLLER_IP>/identity
                os_privileged_user_name = nova
                logging_exception_prefix = %(color)s%(asctime)s.%(msecs)03d TRACE %(name)s [01;35m%(instance)s[00m
                logging_debug_format_suffix = [00;33mfrom (pid=%(process)d) %(funcName)s %(pathname)s:%(lineno)d[00m
                logging_default_format_string = %(asctime)s.%(msecs)03d %(color)s%(levelname)s %(name)s [[00;36m-%(color)s] [01;35m%(instance)s%(color)s%(message)s[00m
                logging_context_format_string = %(asctime)s.%(msecs)03d %(color)s%(levelname)s %(name)s [[01;36m%(request_id)s [00;36m%(project_name)s %(user_name)s%(color)s] [01;35m%(instance)s%(color)s%(message)s[00m
                use_syslog = False
                debug = True
                masakari_api_workers = 2
                [database]
                connection = mysql+pymysql://root:admin@1<CONTROLLER_IP>/masakari?charset=utf8
                [keystone_authtoken]
                memcached_servers = localhost:11211
                cafile = /opt/stack/data/ca-bundle.pem
                project_domain_name = Default
                project_name = service
                user_domain_name = Default
                password = <MASAKARI_PASS>
                username = masakari
                auth_url = http://<CONTROLLER_IP>/identity
                auth_type = password
                [taskflow]
                connection = mysql+pymysql://root:admin@<CONTROLLER_IP>/masakari?charset=utf8
             NOTE:
                Replace CONTROLLER_IP with the IP address of controller node.
                Replace MASAKARI_PASS with the password you chose for the masakari user in the Identity service.
          4. Create masakari directory in /etc/:
             Copy masakari.conf file to /etc/masakari/
                # cp -p etc/masakari/masakari.conf.sample /etc/masakari/masakari.conf
       3. To install masakari run setup.py from masakari:
             # cd masakari
             # sudo python -m pip install -r requirements.txt
             # sudo python setup.py install
       4. Run below db command to sync database:
             # masakari-manage db sync
   Finalize installation
       • Start masakari services:
            # masakari-api
            # masakari-engine
   Verify operation
       Verify Masakari installation.
       1. Source the admin credentials to gain access to admin-only CLI commands:
             $ . admin-openrc
       2. List API endpoints in the Identity service to verify connectivity with the Identity service:
          NOTE:
             Below endpoints list may differ depending on the installation of OpenStack components.
             $ openstack endpoint list
             +-------------+----------------+--------------------------------------------------------+
             | Name        | Type           | Endpoints                                              |
             +-------------+----------------+--------------------------------------------------------+
             | nova_legacy | compute_legacy | RegionOne                                              |
             |             |                |   public: http://controller/compute/v2/<tenant_id>     |
             |             |                |                                                        |
             | nova        | compute        | RegionOne                                              |
             |             |                |   public: http://controller/compute/v2.1               |
             |             |                |                                                        |
             | cinder      | block-storage  | RegionOne                                              |
             |             |                |   public: http://controller/volume/v3/<tenant_id>      |
             |             |                |                                                        |
             | glance      | image          | RegionOne                                              |
             |             |                |   public: http://controller/image                      |
             |             |                |                                                        |
             | cinderv3    | volumev3       | RegionOne                                              |
             |             |                |   public: http://controller/volume/v3/<tenant_id>      |
             |             |                |                                                        |
             | masakari    | instance-ha    | RegionOne                                              |
             |             |                | internal: http://controller/instance-ha/v1/<tenant_id> |
             |             |                | RegionOne                                              |
             |             |                |  admin: http://controller/instance-ha/v1/<tenant_id>   |
             |             |                | RegionOne                                              |
             |             |                |  public: http://controller/instance-ha/v1/<tenant_id>  |
             |             |                |                                                        |
             | keystone    | identity       | RegionOne                                              |
             |             |                |   public: http://controller/identity                   |
             |             |                | RegionOne                                              |
             |             |                |   admin: http://controller/identity                    |
             |             |                |                                                        |
             | cinderv2    | volumev2       | RegionOne                                              |
             |             |                |   public: http://controller/volume/v2/<tenant_id>      |
             |             |                |                                                        |
             | placement   | placement      | RegionOne                                              |
             |             |                |   public: http://controller/placement                  |
             |             |                |                                                        |
             | neutron     | network        | RegionOne                                              |
             |             |                |   public: http://controller:9696/                      |
             |             |                |                                                        |
             +-------------+----------------+--------------------------------------------------------+
       3. Run segment list command to verify masakari-api is running properly.  This will return  empty  segment
          list as you haven’t yet configured Failover segments.
             $ openstack segment list
          NOTE:
             Since  Failover  segments  are not configured, there is no way to verify masakari-engine is running
             properly as the notification cannot be sent from masakari-api to masakari-engine.
   Reference Material
       • Configuration Guide: Information on configuration files.
       • Custom Recovery Workflow Configuration Guide
       • CLI Commands for Masakari: The complete command reference for Masakari.
       • Versioned Notifications: This provides  the  list  of  existing  versioned  notifications  with  sample
         payloads.  This will help newcomers understand basics of Masakari
       • Nova Docs: A collection of guides for Nova.
   Masakari CLI Documentation
       In this section you will find information on Masakari’s command line interface.
   masakari-status
   CLI interface for Masakari status commands
   Synopsis
          masakari-status <category> <command> [<args>]
   Description
       masakari-status is a tool that provides routines for checking the status of a Masakari deployment.
   Options
       The standard pattern for executing a masakari-status command is:
          masakari-status <category> <command> [<args>]
       Run without arguments to see a list of available command categories:
          masakari-status
       Categories are:
       • upgrade
       Detailed descriptions are below:
       You can also run with a category argument such as upgrade to see a list of all commands in that category:
          masakari-status upgrade
       These sections describe the available categories and arguments for masakari-status.
   Upgrade
       masakari-status upgrade check
              Performs a release-specific readiness check before restarting services with new code. For example,
              missing  or  changed  configuration  options, incompatible object states, or other conditions that
              could lead to failures while upgrading.
              Return Codes
                                   ┌─────────────┬───────────────────────────────────────┐
                                   │ Return code │ Description                           │
                                   ├─────────────┼───────────────────────────────────────┤
                                   │ 0           │ All upgrade readiness  checks  passed │
                                   │             │ successfully  and there is nothing to │
                                   │             │ do.                                   │
                                   ├─────────────┼───────────────────────────────────────┤
                                   │ 1           │ At least  one  check  encountered  an │
                                   │             │ issue     and     requires    further │
                                   │             │ investigation. This is  considered  a │
                                   │             │ warning but the upgrade may be OK.    │
                                   ├─────────────┼───────────────────────────────────────┤
                                   │ 2           │ There  was  an  upgrade  status check │
                                   │             │ failure    that    needs    to     be │
                                   │             │ investigated.    This    should    be │
                                   │             │ considered something  that  stops  an │
                                   │             │ upgrade.                              │
                                   ├─────────────┼───────────────────────────────────────┤
                                   │ 255         │ An unexpected error occurred.         │
                                   └─────────────┴───────────────────────────────────────┘
              History of Checks
              7.0.0 (Stein)
              • Sample check to be filled in with checks as they are added in Stein.
   masakari-manage
   Control and manage masakari database
   Synopsis
          masakari-manage <category> <action> [<args>]
   Description
       masakari-manage controls DB by managing various admin-only aspects of masakari.
   Options
       The standard pattern for executing a masakari-manage command is:
          masakari-manage <category> <command> [<args>]
       Run without arguments to see a list of available command categories:
          masakari-manage
       You can also run with a category argument such as db to see a list of all commands in that category:
          masakari-manage db
       These sections describe the available categories and arguments for masakari-manage.
   Masakari Database
       masakari-manage db version
              Print the current main database version.
       masakari-manage db sync [--version <version>]
              Upgrade the main database schema up to the most recent version or --version if specified.
       masakari-manage db purge
              Deleting rows older than 30 day(s) from table hosts, failover_segments and notifications.
   openstack masakari
       To control and manage masakari operations, the extended command list available in openstack command.
   api-paste.ini
       The masakari service stores its API configuration settings in the api-paste.ini file.
          [composite:masakari_api]
          use = call:masakari.api.urlmap:urlmap_factory
          /: apiversions
          /v1: masakari_api_v1
          [composite:masakari_api_v1]
          use = call:masakari.api.auth:pipeline_factory_v1
          keystone = cors http_proxy_to_wsgi request_id faultwrap sizelimit authtoken keystonecontext osapi_masakari_app_v1
          noauth2 = cors http_proxy_to_wsgi request_id faultwrap sizelimit noauth2 osapi_masakari_app_v1
          # filters
          [filter:cors]
          paste.filter_factory = oslo_middleware.cors:filter_factory
          oslo_config_project = masakari
          [filter:http_proxy_to_wsgi]
          paste.filter_factory = oslo_middleware.http_proxy_to_wsgi:HTTPProxyToWSGI.factory
          [filter:request_id]
          paste.filter_factory = oslo_middleware:RequestId.factory
          [filter:faultwrap]
          paste.filter_factory = masakari.api.openstack:FaultWrapper.factory
          [filter:sizelimit]
          paste.filter_factory = oslo_middleware:RequestBodySizeLimiter.factory
          [filter:authtoken]
          paste.filter_factory = keystonemiddleware.auth_token:filter_factory
          [filter:keystonecontext]
          paste.filter_factory = masakari.api.auth:MasakariKeystoneContext.factory
          [filter:noauth2]
          paste.filter_factory = masakari.api.auth:NoAuthMiddleware.factory
          # apps
          [app:osapi_masakari_app_v1]
          paste.app_factory = masakari.api.openstack.ha:APIRouterV1.factory
          [pipeline:apiversions]
          pipeline = faultwrap http_proxy_to_wsgi apiversionsapp
          [app:apiversionsapp]
          paste.app_factory = masakari.api.openstack.ha.versions:Versions.factory
   Configuration Options
       The following is an overview of all available configuration options in Masakari.
   DEFAULT
       auth_strategy
              Type   string
              Default
                     keystone
              Valid Values
                     keystone, noauth2
              This  determines  the  strategy  to  use  for  authentication:  keystone or noauth2.  ‘noauth2’ is
              designed for  testing  only,  as  it  does  no  actual  credential  checking.  ‘noauth2’  provides
              administrative credentials only if ‘admin’ is specified as the username.
              • Possible values:
                Either ‘keystone’ (default) or ‘noauth2’.
              • Services that use this:
                masakari-api
              • Related options:
                None
       use_forwarded_for
              Type   boolean
              Default
                     False
              When  True,  the  ‘X-Forwarded-For’  header is treated as the canonical remote address. When False
              (the default), the ‘remote_address’ header is used.
              You should only enable this if you have an HTML sanitizing proxy.
              • Possible values:
                True, False (default)
              • Services that use this:
                masakari-api
              • Related options:
                None
       osapi_max_limit
              Type   integer
              Default
                     1000
              As a query can potentially return many thousands of items, you can limit  the  maximum  number  of
              items in a single response by setting this option.
              • Possible values:
                Any positive integer. Default is 1000.
              • Services that use this:
                masakari-api
              • Related options:
                None
       osapi_masakari_link_prefix
              Type   string
              Default
                     <None>
              This  string  is  prepended  to the normal URL that is returned in links to the OpenStack Masakari
              API. If it is empty (the default), the URLs are returned unchanged.
              • Possible values:
                Any string, including an empty string (the default).
              • Services that use this:
                masakari-api
              • Related options:
                None
       tempdir
              Type   string
              Default
                     <None>
              Explicitly specify the temporary working directory.
       monkey_patch
              Type   boolean
              Default
                     False
              Determine if monkey patching should be applied.
              Related options:
              • monkey_patch_modules: This must have values set for this option to have any effect
       monkey_patch_modules
              Type   list
              Default
                     ['masakari.api:masakari.cmd']
              List of modules/decorators to monkey patch.
              This option allows you to patch a decorator for all functions in specified modules.
              Related options:
              • monkey_patch: This must be set to True for this option to have any effect
       masakari_topic
              Type   string
              Default
                     ha_engine
              This is the message queue topic that the masakari  engine  ‘listens’  on.  It  is  used  when  the
              masakari  engine  is  started  up to configure the queue, and whenever an RPC call to the masakari
              engine is made.
              • Possible values:
                Any string, but there is almost never any reason to ever change this value from its  default  of
                ‘engine’.
              • Services that use this:
                masakari-engine
              • Related options:
                None
              WARNING:
                 This  option  is  deprecated for removal since 3.0.0.  Its value may be silently ignored in the
                 future.
                 Reason Configurable RPC topic provides little  value  and  it  can  easily  break  Masakari  if
                        operator configures it to the same topic used by other OpenStack services.
       duplicate_notification_detection_interval
              Type   integer
              Default
                     180
              Minimum Value
                     0
              Interval  in  seconds  for  identifying  duplicate  notifications. If the notification received is
              identical to the previous ones whose status is either new or running and if it’s created_timestamp
              and the current timestamp is less than this config option value, then  the  notification  will  be
              considered as duplicate and it will be ignored.
       wait_period_after_service_update
              Type   integer
              Default
                     180
              Number of seconds to wait after a service is enabled or disabled.
       wait_period_after_evacuation
              Type   integer
              Default
                     90
              Wait until instance is evacuated
       verify_interval
              Type   integer
              Default
                     1
              The monitoring interval for looping
       wait_period_after_power_off
              Type   integer
              Default
                     180
              Number of seconds to wait for instance to shut down
       wait_period_after_power_on
              Type   integer
              Default
                     60
              Number of seconds to wait for instance to start
       process_unfinished_notifications_interval
              Type   integer
              Default
                     120
              Interval in seconds for processing notifications which are in error or new state.
       retry_notification_new_status_interval
              Type   integer
              Default
                     60
              Mutable
                     This option can be changed without restarting.
              Interval  in  seconds for identifying notifications which are in new state. If the notification is
              in new state till this config option value after it’s generated_time, then it is  considered  that
              notification    is    ignored    by    the    messaging   queue   and   will   be   processed   by
              ‘process_unfinished_notifications’ periodic task.
       check_expired_notifications_interval
              Type   integer
              Default
                     600
              Interval in seconds for checking running notifications.
       notifications_expired_interval
              Type   integer
              Default
                     86400
              Interval in seconds for identifying running notifications expired.
       host_failure_recovery_threads
              Type   integer
              Default
                     3
              Minimum Value
                     1
              Number of threads to  be  used  for  evacuating  and  confirming  instances  during  execution  of
              host_failure workflow.
       notification_driver
              Type   string
              Default
                     taskflow_driver
              Defines which driver to use for executing notification workflows.
       fatal_exception_format_errors
              Type   boolean
              Default
                     False
              Make exception message format errors fatal
       nova_catalog_admin_info
              Type   string
              Default
                     compute:nova:publicURL
              Match  this  value  when searching for nova in the service catalog. Format is: separated values of
              the form: <service_type>:<service_name>:<endpoint_type>
       os_region_name
              Type   string
              Default
                     <None>
              Region name of this node
       nova_ca_certificates_file
              Type   string
              Default
                     <None>
              Location of ca certificates file to use for nova client requests.
       nova_api_insecure
              Type   boolean
              Default
                     False
              Allow to perform insecure SSL requests to nova
       os_privileged_user_name
              Type   string
              Default
                     <None>
              OpenStack privileged account username. Used for requests to other services  (such  as  Nova)  that
              require an account with special rights.
       os_privileged_user_password
              Type   string
              Default
                     <None>
              Password associated with the OpenStack privileged account.
       os_privileged_user_tenant
              Type   string
              Default
                     <None>
              Tenant name associated with the OpenStack privileged account.
       os_privileged_user_auth_url
              Type   URI
              Default
                     <None>
              Auth URL associated with the OpenStack privileged account.
       os_user_domain_name
              Type   string
              Default
                     default
              User domain name associated with the OpenStack privileged account.
       os_project_domain_name
              Type   string
              Default
                     default
              Project domain name associated with the OpenStack privileged account.
       os_system_scope
              Type   string
              Default
                     <None>
              Scope for system operations.
       pybasedir
              Type   string
              Default
                     /build/masakari-WWqACF/masakari-19.0.0
              Directory where the masakari python module is installed
       bindir
              Type   string
              Default
                     /usr/local/bin
              Directory where masakari binaries are installed
       state_path
              Type   string
              Default
                     $pybasedir
              Top-level directory for maintaining masakari’s state
       host
              Type   host address
              Default
                     lcy02-amd64-028
              Hostname, FQDN or IP address of this host. Must be valid within AMQP key.
              Possible values:
              • String with hostname, FQDN or IP address. Default is hostname of this host.
       engine_manager
              Type   string
              Default
                     masakari.engine.manager.MasakariManager
              Full class name for the Manager for masakari engine
       report_interval
              Type   integer
              Default
                     10
              Seconds between nodes reporting state to datastore
       periodic_enable
              Type   boolean
              Default
                     True
              Enable periodic tasks
       periodic_interval_max
              Type   integer
              Default
                     300
              Max interval time between periodic tasks execution in seconds.
       periodic_fuzzy_delay
              Type   integer
              Default
                     60
              Range of seconds to randomly delay when starting the periodic task scheduler to reduce stampeding.
              (Disable by setting to 0)
       use_ssl
              Type   boolean
              Default
                     False
              Use APIs with SSL enabled
       masakari_api_listen
              Type   host address
              Default
                     0.0.0.0
              The IP address on which the Masakari API will listen.
       masakari_api_listen_port
              Type   integer
              Default
                     15868
              Minimum Value
                     1
              Maximum Value
                     65535
              The port on which the Masakari API will listen.
       masakari_api_workers
              Type   integer
              Default
                     <None>
              Number of workers for Masakari API service. The default will be the number of CPUs available.
       service_down_time
              Type   integer
              Default
                     60
              Maximum time since last check-in for up service
       backdoor_port
              Type   string
              Default
                     <None>
              Enable  eventlet backdoor.  Acceptable values are 0, <port>, and <start>:<end>, where 0 results in
              listening on a random tcp port number; <port> results in listening on the  specified  port  number
              (and  not enabling backdoor if that port is in use); and <start>:<end> results in listening on the
              smallest unused port number within the specified  range  of  port  numbers.  The  chosen  port  is
              displayed in the service’s log file.
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason The ‘backdoor_port’ option is deprecated and will be removed in a future release.
       backdoor_socket
              Type   string
              Default
                     <None>
              Enable  eventlet  backdoor, using the provided path as a unix socket that can receive connections.
              This option is mutually exclusive with ‘backdoor_port’ in that only one  should  be  provided.  If
              both are provided then the existence of this option overrides the usage of that option. Inside the
              path {pid} will be replaced with the PID of the current process.
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason The ‘backdoor_socket’ option is deprecated and will be removed in a future release.
       log_options
              Type   boolean
              Default
                     True
              Enables  or  disables  logging  values of all registered options when starting a service (at DEBUG
              level).
       graceful_shutdown_timeout
              Type   integer
              Default
                     60
              Specify a timeout after which a gracefully shutdown server will exit.  Zero  value  means  endless
              wait.
       api_paste_config
              Type   string
              Default
                     api-paste.ini
              File name for the paste.deploy config for api service
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason The ‘api_paste_config’ option is deprecated and will be removed in a future release.
       wsgi_log_format
              Type   string
              Default
                     %(client_ip)s   "%(request_line)s"  status:  %(status_code)s   len:  %(body_length)s  time:
                     %(wall_seconds).7f
              A python format string that is used as the template to generate log lines.  The  following  values
              can   beformatted   into   it:   client_ip,  date_time,  request_line,  status_code,  body_length,
              wall_seconds.
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason The ‘wsgi_log_format’ option is deprecated and will be removed in a future release.
       tcp_keepidle
              Type   integer
              Default
                     600
              Sets the value of TCP_KEEPIDLE in seconds for each server socket. Not supported on OS X.
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason The ‘tcp_keepidle’ option is deprecated and will be removed in a future release.
       wsgi_default_pool_size
              Type   integer
              Default
                     100
              Size of the pool of greenthreads used by wsgi
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason The ‘wsgi_default_pool_size’ option is deprecated  and  will  be  removed  in  a  future
                        release.
       max_header_line
              Type   integer
              Default
                     16384
              Maximum line size of message headers to be accepted. max_header_line may need to be increased when
              using  large  tokens (typically those generated when keystone is configured to use PKI tokens with
              big service catalogs).
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason The ‘max_header_line’ option is deprecated and will be removed in a future release.
       wsgi_keep_alive
              Type   boolean
              Default
                     True
              If False, closes the client socket connection explicitly.
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason The ‘wsgi_keep_alive’ option is deprecated and will be removed in a future release.
       client_socket_timeout
              Type   integer
              Default
                     900
              Timeout for client connections’ socket operations. If an incoming  connection  is  idle  for  this
              number of seconds it will be closed. A value of ‘0’ means wait forever.
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason The  ‘client_socket_timeout’  option  is  deprecated  and  will  be  removed in a future
                        release.
       wsgi_server_debug
              Type   boolean
              Default
                     False
              True if the server should send exception tracebacks to the clients on 500 errors.  If  False,  the
              server will respond with empty bodies.
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason The ‘wsgi_server_debug’ option is deprecated and will be removed in a future release.
       debug
              Type   boolean
              Default
                     False
              Mutable
                     This option can be changed without restarting.
              If set to true, the logging level will be set to DEBUG instead of the default INFO level.
       log_config_append
              Type   string
              Default
                     <None>
              Mutable
                     This option can be changed without restarting.
              The  name  of  a  logging  configuration  file.  This  file  is  appended  to any existing logging
              configuration files. For details about logging configuration files, see the Python logging  module
              documentation.  Note that when logging configuration files are used then all logging configuration
              is set in the configuration file and other logging configuration options are ignored (for example,
              log-date-format).
   Deprecated Variations
                                               ┌─────────┬────────────┐
                                               │ Group   │ Name       │
                                               ├─────────┼────────────┤
                                               │ DEFAULT │ log-config │
                                               ├─────────┼────────────┤
                                               │ DEFAULT │ log_config │
                                               └─────────┴────────────┘
       log_date_format
              Type   string
              Default
                     %Y-%m-%d %H:%M:%S
              Defines the format string for %(asctime)s in log records. Default: the value above .  This  option
              is ignored if log_config_append is set.
       log_file
              Type   string
              Default
                     <None>
              (Optional)  Name  of  log file to send logging output to. If no default is set, logging will go to
              stderr as defined by use_stderr. This option is ignored if log_config_append is set.
   Deprecated Variations
                                                ┌─────────┬─────────┐
                                                │ Group   │ Name    │
                                                ├─────────┼─────────┤
                                                │ DEFAULT │ logfile │
                                                └─────────┴─────────┘
       log_dir
              Type   string
              Default
                     <None>
              (Optional) The base directory used for  relative  log_file   paths.  This  option  is  ignored  if
              log_config_append is set.
   Deprecated Variations
                                                 ┌─────────┬────────┐
                                                 │ Group   │ Name   │
                                                 ├─────────┼────────┤
                                                 │ DEFAULT │ logdir │
                                                 └─────────┴────────┘
       watch_log_file
              Type   boolean
              Default
                     False
              Uses logging handler designed to watch file system. When log file is moved or removed this handler
              will  open  a  new  log  file with specified path instantaneously. It makes sense only if log_file
              option is specified and Linux platform is used. This option is  ignored  if  log_config_append  is
              set.
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason This  function  is  known  to  have  bene  broken  for  long  time,  and  depends on the
                        unmaintained library
       use_syslog
              Type   boolean
              Default
                     False
              Use syslog for logging. Existing syslog format is DEPRECATED and will be changed  later  to  honor
              RFC5424. This option is ignored if log_config_append is set.
       use_journal
              Type   boolean
              Default
                     False
              Enable  journald  for  logging. If running in a systemd environment you may wish to enable journal
              support. Doing so will use the journal native  protocol  which  includes  structured  metadata  in
              addition to log messages.This option is ignored if log_config_append is set.
       syslog_log_facility
              Type   string
              Default
                     LOG_USER
              Syslog facility to receive log lines. This option is ignored if log_config_append is set.
       use_json
              Type   boolean
              Default
                     False
              Use JSON formatting for logging. This option is ignored if log_config_append is set.
       use_stderr
              Type   boolean
              Default
                     False
              Log output to standard error. This option is ignored if log_config_append is set.
       log_color
              Type   boolean
              Default
                     False
              (Optional) Set the ‘color’ key according to log levels. This option takes effect only when logging
              to stderr or stdout is used. This option is ignored if log_config_append is set.
       log_rotate_interval
              Type   integer
              Default
                     1
              The   amount   of  time  before  the  log  files  are  rotated.  This  option  is  ignored  unless
              log_rotation_type is set to “interval”.
       log_rotate_interval_type
              Type   string
              Default
                     days
              Valid Values
                     Seconds, Minutes, Hours, Days, Weekday, Midnight
              Rotation interval type. The time of the last file  change  (or  the  time  when  the  service  was
              started) is used when scheduling the next rotation.
       max_logfile_count
              Type   integer
              Default
                     30
              Maximum number of rotated log files.
       max_logfile_size_mb
              Type   integer
              Default
                     200
              Log file maximum size in MB. This option is ignored if “log_rotation_type” is not set to “size”.
       log_rotation_type
              Type   string
              Default
                     none
              Valid Values
                     interval, size, none
              Log rotation type.
              Possible values
              interval
                     Rotate logs at predefined time intervals.
              size   Rotate logs once they reach a predefined size.
              none   Do not rotate log files.
       logging_context_format_string
              Type   string
              Default
                     %(asctime)s.%(msecs)03d    %(process)d    %(levelname)s   %(name)s   [%(global_request_id)s
                     %(request_id)s %(user_identity)s] %(instance)s%(message)s
              Format string to use for log messages with context. Used by oslo_log.formatters.ContextFormatter
       logging_default_format_string
              Type   string
              Default
                     %(asctime)s.%(msecs)03d %(process)d %(levelname)s %(name)s [-] %(instance)s%(message)s
              Format   string   to   use   for   log   messages   when   context   is   undefined.    Used    by
              oslo_log.formatters.ContextFormatter
       logging_debug_format_suffix
              Type   string
              Default
                     %(funcName)s %(pathname)s:%(lineno)d
              Additional  data  to  append  to  log message when logging level for the message is DEBUG. Used by
              oslo_log.formatters.ContextFormatter
       logging_exception_prefix
              Type   string
              Default
                     %(asctime)s.%(msecs)03d %(process)d ERROR %(name)s %(instance)s
              Prefix    each    line    of    exception     output     with     this     format.     Used     by
              oslo_log.formatters.ContextFormatter
       logging_user_identity_format
              Type   string
              Default
                     %(user)s %(project)s %(domain)s %(system_scope)s %(user_domain)s %(project_domain)s
              Defines  the  format  string  for %(user_identity)s that is used in logging_context_format_string.
              Used by oslo_log.formatters.ContextFormatter
       default_log_levels
              Type   list
              Default
                     ['amqp=WARN', 'amqplib=WARN',  'boto=WARN',  'qpid=WARN',  'sqlalchemy=WARN',  'suds=INFO',
                     'oslo.messaging=INFO',                'oslo_messaging=INFO',                'iso8601=WARN',
                     'requests.packages.urllib3.connectionpool=WARN',             'urllib3.connectionpool=WARN',
                     'websocket=WARN',  'requests.packages.urllib3.util.retry=WARN',  'urllib3.util.retry=WARN',
                     'keystonemiddleware=WARN',  'routes.middleware=WARN',  'stevedore=WARN',   'taskflow=WARN',
                     'keystoneauth=WARN', 'oslo.cache=INFO', 'oslo_policy=INFO', 'dogpile.core.dogpile=INFO']
              List  of package logging levels in logger=LEVEL pairs. This option is ignored if log_config_append
              is set.
       publish_errors
              Type   boolean
              Default
                     False
              Enables or disables publication of error events.
       instance_format
              Type   string
              Default
                     "[instance: %(uuid)s] "
              The format for an instance that is passed with the log message.
       instance_uuid_format
              Type   string
              Default
                     "[instance: %(uuid)s] "
              The format for an instance UUID that is passed with the log message.
       rate_limit_interval
              Type   integer
              Default
                     0
              Interval, number of seconds, of log rate limiting.
       rate_limit_burst
              Type   integer
              Default
                     0
              Maximum number of logged messages per rate_limit_interval.
       rate_limit_except_level
              Type   string
              Default
                     CRITICAL
              Valid Values
                     CRITICAL, ERROR, INFO, WARNING, DEBUG, ‘’
              Log level name used by rate limiting. Logs with level greater or equal to  rate_limit_except_level
              are not filtered. An empty string means that all levels are filtered.
       fatal_deprecations
              Type   boolean
              Default
                     False
              Enables or disables fatal status of deprecations.
       executor_thread_pool_size
              Type   integer
              Default
                     64
              Size of executor thread pool when executor is threading or eventlet.
   Deprecated Variations
                                          ┌─────────┬──────────────────────┐
                                          │ Group   │ Name                 │
                                          ├─────────┼──────────────────────┤
                                          │ DEFAULT │ rpc_thread_pool_size │
                                          └─────────┴──────────────────────┘
       rpc_response_timeout
              Type   integer
              Default
                     60
              Seconds to wait for a response from a call.
       transport_url
              Type   string
              Default
                     rabbit://
              The  network address and optional user credentials for connecting to the messaging backend, in URL
              format. The expected format is:
              driver://[user:pass@]host:port[,[userN:passN@]hostN:portN]/virtual_host?query
              Example: rabbit://rabbitmq:password@127.0.0.1:5672//
              For full details on the fields in the URL see the documentation of oslo_messaging.TransportURL  at
              https://docs.openstack.org/oslo.messaging/latest/reference/transport.html
       control_exchange
              Type   string
              Default
                     openstack
              The  default  exchange  under  which  topics  are  scoped.  May  be overridden by an exchange name
              specified in the transport_url option.
       rpc_ping_enabled
              Type   boolean
              Default
                     False
              Add an endpoint to answer to ping calls. Endpoint is named oslo_rpc_server_ping
   coordination
       backend_url
              Type   string
              Default
                     <None>
              The backend URL to use  for  distributed  coordination.By  default  it’s  None  which  means  that
              coordination  is disabled. The coordination is implemented for distributed lock management and was
              tested with etcd.Coordination doesn’t work for file driver because lock files aren’t removed after
              lock releasing.
   cors
       allowed_origin
              Type   list
              Default
                     <None>
              Indicate whether this resource may be shared with the domain received  in  the  requests  “origin”
              header.    Format:    “<protocol>://<host>[:<port>]”,    no    trailing    slash.    Example:    ‐
              https://horizon.example.com
       allow_credentials
              Type   boolean
              Default
                     True
              Indicate that the actual request can include user credentials
       expose_headers
              Type   list
              Default
                     []
              Indicate which headers are safe to expose to the API. Defaults to HTTP Simple Headers.
       max_age
              Type   integer
              Default
                     3600
              Maximum cache age of CORS preflight requests.
       allow_methods
              Type   list
              Default
                     ['OPTIONS', 'GET', 'HEAD', 'POST', 'PUT', 'DELETE', 'TRACE', 'PATCH']
              Indicate which methods can be used during the actual request.
       allow_headers
              Type   list
              Default
                     []
              Indicate which header field names may be used during the actual request.
   database
       sqlite_synchronous
              Type   boolean
              Default
                     True
              If True, SQLite uses synchronous mode.
       backend
              Type   string
              Default
                     sqlalchemy
              The back end to use for the database.
       connection
              Type   string
              Default
                     <None>
              The SQLAlchemy connection string to use to connect to the database.
       slave_connection
              Type   string
              Default
                     <None>
              The SQLAlchemy connection string to use to connect to the slave database.
       asyncio_connection
              Type   string
              Default
                     <None>
              The SQLAlchemy asyncio connection string to use to connect to the database.
       asyncio_slave_connection
              Type   string
              Default
                     <None>
              The SQLAlchemy asyncio connection string to use to connect to the slave database.
       mysql_sql_mode
              Type   string
              Default
                     TRADITIONAL
              The SQL mode to be used for MySQL sessions. This option,  including  the  default,  overrides  any
              server-set  SQL  mode. To use whatever SQL mode is set by the server configuration, set this to no
              value. Example: mysql_sql_mode=
       mysql_wsrep_sync_wait
              Type   integer
              Default
                     <None>
              For Galera only, configure wsrep_sync_wait causality checks on new connections.  Default is  None,
              meaning don’t configure any setting.
       connection_recycle_time
              Type   integer
              Default
                     3600
              Connections which have been present in the connection pool longer than this number of seconds will
              be replaced with a new one the next time they are checked out from the pool.
       max_pool_size
              Type   integer
              Default
                     5
              Maximum number of SQL connections to keep open in a pool. Setting a value of 0 indicates no limit.
       max_retries
              Type   integer
              Default
                     10
              Maximum  number  of  database  connection retries during startup. Set to -1 to specify an infinite
              retry count.
       retry_interval
              Type   integer
              Default
                     10
              Interval between retries of opening a SQL connection.
       max_overflow
              Type   integer
              Default
                     50
              If set, use this value for max_overflow with SQLAlchemy.
       connection_debug
              Type   integer
              Default
                     0
              Minimum Value
                     0
              Maximum Value
                     100
              Verbosity of SQL debugging information: 0=None, 100=Everything.
       connection_trace
              Type   boolean
              Default
                     False
              Add Python stack traces to SQL as comment strings.
       pool_timeout
              Type   integer
              Default
                     <None>
              If set, use this value for pool_timeout with SQLAlchemy.
       use_db_reconnect
              Type   boolean
              Default
                     False
              Enable the experimental use of database reconnect on connection lost.
       db_retry_interval
              Type   integer
              Default
                     1
              Seconds between retries of a database transaction.
       db_inc_retry_interval
              Type   boolean
              Default
                     True
              If  True,  increases  the   interval   between   retries   of   a   database   operation   up   to
              db_max_retry_interval.
       db_max_retry_interval
              Type   integer
              Default
                     10
              If db_inc_retry_interval is set, the maximum seconds between retries of a database operation.
       db_max_retries
              Type   integer
              Default
                     20
              Maximum retries in case of connection error or deadlock error before error is raised. Set to -1 to
              specify an infinite retry count.
       connection_parameters
              Type   string
              Default
                     ''
              Optional  URL  parameters  to  append  onto  the  connection  URL  at  connect  time;  specify  as
              param1=value1¶m2=value2&…
   healthcheck
       path
              Type   string
              Default
                     /healthcheck
              The path to respond to healtcheck requests on.
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
       detailed
              Type   boolean
              Default
                     False
              Show more detailed information as part of the response. Security note: Enabling  this  option  may
              expose  sensitive  details  about  the service being monitored. Be sure to verify that it will not
              violate your security policies.
       backends
              Type   list
              Default
                     []
              Additional backends that can perform health checks and report that information back as part  of  a
              request.
       allowed_source_ranges
              Type   list
              Default
                     []
              A  list  of  network  addresses  to limit source ip allowed to access healthcheck information. Any
              request from ip outside of these network addresses are ignored.
       ignore_proxied_requests
              Type   boolean
              Default
                     False
              Ignore requests with proxy headers.
       disable_by_file_path
              Type   string
              Default
                     <None>
              Check the presence of a file to determine if  an  application  is  running  on  a  port.  Used  by
              DisableByFileHealthcheck plugin.
       disable_by_file_paths
              Type   list
              Default
                     []
              Check  the presence of a file based on a port to determine if an application is running on a port.
              Expects a “port:path” list of strings. Used by DisableByFilesPortsHealthcheck plugin.
       enable_by_file_paths
              Type   list
              Default
                     []
              Check the presence of files. Used by EnableByFilesHealthcheck plugin.
   host_failure
       evacuate_all_instances
              Type   boolean
              Default
                     True
              Operators  can   decide   whether   all   instances   or   only   those   instances   which   have
              [host_failure]\ha_enabled_instance_metadata_key  set to True should be allowed for evacuation from
              a failed source compute node.  When set to True, it will evacuate  all  instances  from  a  failed
              source   compute   node.    First   preference  will  be  given  to  those  instances  which  have
              [host_failure]\ha_enabled_instance_metadata_key set  to  True,  and  then  it  will  evacuate  the
              remaining   ones.   When  set  to  False,  it  will  evacuate  only  those  instances  which  have
              [host_failure]\ha_enabled_instance_metadata_key set to True.
       ha_enabled_instance_metadata_key
              Type   string
              Default
                     HA_Enabled
              Operators can decide on the instance metadata key naming that affects the  per-instance  behaviour
              of  [host_failure]\evacuate_all_instances.   The default is the same for both failure types (host,
              instance) but the value can be overridden to make the metadata key different per failure type.
       ignore_instances_in_error_state
              Type   boolean
              Default
                     False
              Operators can decide whether error instances should be allowed for evacuation from a failed source
              compute node or not. When set to True, it will ignore  error  instances  from  evacuation  from  a
              failed  source  compute node. When set to False, it will evacuate error instances along with other
              instances from a failed source compute node.
       add_reserved_host_to_aggregate
              Type   boolean
              Default
                     False
              Operators can decide whether reserved_host should be added to aggregate group  of  failed  compute
              host. When set to True, reserved host will be added to the aggregate group of failed compute host.
              When  set  to  False, the reserved_host will not be added to the aggregate group of failed compute
              host.
       service_disable_reason
              Type   string
              Default
                     Masakari detected host failed.
              Compute disable reason in case Masakari detects host failure.
   instance_failure
       process_all_instances
              Type   boolean
              Default
                     False
              Operators  can   decide   whether   all   instances   or   only   those   instances   which   have
              [instance_failure]\ha_enabled_instance_metadata_key  set  to  True should be taken into account to
              recover from instance failure events.  When set to True, it will execute instance failure recovery
              actions   for   an   instance   irrespective   of   whether   that   particular    instance    has
              [instance_failure]\ha_enabled_instance_metadata_key  set to True.  When set to False, it will only
              execute    instance    failure    recovery    actions    for     an     instance     which     has
              [instance_failure]\ha_enabled_instance_metadata_key set to True.
       ha_enabled_instance_metadata_key
              Type   string
              Default
                     HA_Enabled
              Operators  can  decide on the instance metadata key naming that affects the per-instance behaviour
              of [instance_failure]\process_all_instances.  The default is  the  same  for  both  failure  types
              (host,  instance)  but  the value can be overridden to make the metadata key different per failure
              type.
   keystone_authtoken
       www_authenticate_uri
              Type   string
              Default
                     <None>
              Complete “public” Identity API endpoint. This endpoint should not be an “admin”  endpoint,  as  it
              should  be accessible by all end users. Unauthenticated clients are redirected to this endpoint to
              authenticate. Although this endpoint should ideally be unversioned, client  support  in  the  wild
              varies.  If  you’re  using a versioned v2 endpoint here, then this should not be the same endpoint
              the service user utilizes for validating tokens, because normal end users may not be able to reach
              that endpoint.
   Deprecated Variations
                                          ┌────────────────────┬──────────┐
                                          │ Group              │ Name     │
                                          ├────────────────────┼──────────┤
                                          │ keystone_authtoken │ auth_uri │
                                          └────────────────────┴──────────┘
       auth_uri
              Type   string
              Default
                     <None>
              Complete “public” Identity API endpoint. This endpoint should not be an “admin”  endpoint,  as  it
              should  be accessible by all end users. Unauthenticated clients are redirected to this endpoint to
              authenticate. Although this endpoint should ideally be unversioned, client  support  in  the  wild
              varies.  If  you’re  using a versioned v2 endpoint here, then this should not be the same endpoint
              the service user utilizes for validating tokens, because normal end users may not be able to reach
              that endpoint. This option is deprecated in favor of www_authenticate_uri and will be  removed  in
              the S release.
              WARNING:
                 This  option  is deprecated for removal since Queens.  Its value may be silently ignored in the
                 future.
                 Reason The auth_uri option is deprecated in favor of www_authenticate_uri and will  be  removed
                        in the S  release.
       auth_version
              Type   string
              Default
                     <None>
              API version of the Identity API endpoint.
       interface
              Type   string
              Default
                     internal
              Interface to use for the Identity API endpoint. Valid values are “public”, “internal” (default) or
              “admin”.
       delay_auth_decision
              Type   boolean
              Default
                     False
              Do  not  handle  authorization  requests  within  the  middleware,  but delegate the authorization
              decision to downstream WSGI components.
       http_connect_timeout
              Type   integer
              Default
                     <None>
              Request timeout value for communicating with Identity API server.
       http_request_max_retries
              Type   integer
              Default
                     3
              How many times are we trying to reconnect when communicating with Identity API Server.
       cache
              Type   string
              Default
                     <None>
              Request environment key where the Swift cache object is  stored.  When  auth_token  middleware  is
              deployed  with  a Swift cache, use this option to have the middleware share a caching backend with
              swift. Otherwise, use the memcached_servers option instead.
       certfile
              Type   string
              Default
                     <None>
              Required if identity server requires client certificate
       keyfile
              Type   string
              Default
                     <None>
              Required if identity server requires client certificate
       cafile
              Type   string
              Default
                     <None>
              A PEM encoded Certificate Authority to use when verifying HTTPs connections.  Defaults  to  system
              CAs.
       insecure
              Type   boolean
              Default
                     False
              Verify HTTPS connections.
       region_name
              Type   string
              Default
                     <None>
              The region in which the identity server can be found.
       memcached_servers
              Type   list
              Default
                     <None>
              Optionally  specify  a  list  of memcached server(s) to use for caching. If left undefined, tokens
              will instead be cached in-process.
   Deprecated Variations
                                      ┌────────────────────┬──────────────────┐
                                      │ Group              │ Name             │
                                      ├────────────────────┼──────────────────┤
                                      │ keystone_authtoken │ memcache_servers │
                                      └────────────────────┴──────────────────┘
       token_cache_time
              Type   integer
              Default
                     300
              In  order  to  prevent  excessive  effort  spent  validating   tokens,   the   middleware   caches
              previously-seen  tokens  for  a  configurable  duration (in seconds). Set to -1 to disable caching
              completely.
       memcache_security_strategy
              Type   string
              Default
                     None
              Valid Values
                     None, MAC, ENCRYPT
              (Optional) If defined, indicate whether token data should be authenticated  or  authenticated  and
              encrypted. If MAC, token data is authenticated (with HMAC) in the cache. If ENCRYPT, token data is
              encrypted  and  authenticated  in  the  cache.  If the value is not one of these options or empty,
              auth_token will raise an exception on initialization.
       memcache_secret_key
              Type   string
              Default
                     <None>
              (Optional, mandatory if memcache_security_strategy  is  defined)  This  string  is  used  for  key
              derivation.
       memcache_pool_dead_retry
              Type   integer
              Default
                     300
              (Optional) Number of seconds memcached server is considered dead before it is tried again.
       memcache_pool_maxsize
              Type   integer
              Default
                     10
              (Optional) Maximum total number of open connections to every memcached server.
       memcache_pool_socket_timeout
              Type   integer
              Default
                     3
              (Optional) Socket timeout in seconds for communicating with a memcached server.
       memcache_pool_unused_timeout
              Type   integer
              Default
                     60
              (Optional)  Number  of  seconds  a connection to memcached is held unused in the pool before it is
              closed.
       memcache_pool_conn_get_timeout
              Type   integer
              Default
                     10
              (Optional) Number of seconds that an operation will wait to get a memcached client connection from
              the pool.
       memcache_use_advanced_pool
              Type   boolean
              Default
                     True
              (Optional) Use the advanced (eventlet safe) memcached client pool.
       include_service_catalog
              Type   boolean
              Default
                     True
              (Optional) Indicate whether to set the X-Service-Catalog header. If False, middleware will not ask
              for service catalog on token validation and will not set the X-Service-Catalog header.
       enforce_token_bind
              Type   string
              Default
                     permissive
              Used to control the use and type of token binding. Can be set to: “disabled” to  not  check  token
              binding.  “permissive”  (default)  to  validate  binding information if the bind type is of a form
              known to the server and ignore it if not. “strict” like “permissive”  but  if  the  bind  type  is
              unknown  the token will be rejected. “required” any form of token binding is needed to be allowed.
              Finally the name of a binding method that must be present in tokens.
       service_token_roles
              Type   list
              Default
                     ['service']
              A choice of roles that must be present in a service token. Service tokens are allowed  to  request
              that  an  expired  token  can  be  used  and so this check should tightly control that only actual
              services should be sending this token. Roles here are applied as an ANY check so any role in  this
              list  must  be  present.  For  backwards  compatibility  reasons  this  currently only affects the
              allow_expired check.
       service_token_roles_required
              Type   boolean
              Default
                     False
              For backwards compatibility reasons we must let valid service tokens  pass  that  don’t  pass  the
              service_token_roles  check as valid. Setting this true will become the default in a future release
              and should be enabled if possible.
       service_type
              Type   string
              Default
                     <None>
              The name or type of the service as it appears in the service catalog. This  is  used  to  validate
              tokens that have restricted access rules.
       memcache_sasl_enabled
              Type   boolean
              Default
                     False
              Enable  the  SASL(Simple  Authentication  and  Security  Layer)  if  the SASL_enable is true, else
              disable.
       memcache_username
              Type   string
              Default
                     ''
              the user name for the SASL
       memcache_password
              Type   string
              Default
                     ''
              the username password for SASL
       auth_type
              Type   unknown type
              Default
                     <None>
              Authentication type to load
   Deprecated Variations
                                         ┌────────────────────┬─────────────┐
                                         │ Group              │ Name        │
                                         ├────────────────────┼─────────────┤
                                         │ keystone_authtoken │ auth_plugin │
                                         └────────────────────┴─────────────┘
       auth_section
              Type   unknown type
              Default
                     <None>
              Config Section from which to load plugin specific options
   osapi_v1
       extensions_blacklist
              Type   list
              Default
                     []
              DEPRECATED
              This option is a list of all of the v2.1 API extensions to never load. However, it will be removed
              in the near future, after which the all the functionality that was previously in  extensions  will
              be part of the standard API, and thus always accessible.
              • Possible values:
                A list of strings, each being the alias of an extension that you do not wish to load.
              • Services that use this:
                masakari-api
              • Related options:
                enabled, extensions_whitelist
   Deprecated Variations
                                         ┌──────────┬──────────────────────┐
                                         │ Group    │ Name                 │
                                         ├──────────┼──────────────────────┤
                                         │ osapi_v1 │ extensions_blacklist │
                                         └──────────┴──────────────────────┘
       WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
       extensions_whitelist
              Type   list
              Default
                     []
              DEPRECATED
              This  is  a  list of extensions. If it is empty, then all extensions except those specified in the
              extensions_blacklist option will be loaded. If it is not empty, then only those extensions in this
              list will be loaded, provided that they are also not in the extensions_blacklist option. Once this
              deprecated option is removed, after which  the  all  the  functionality  that  was  previously  in
              extensions will be part of the standard API, and thus always accessible.
              • Possible values:
                A list of strings, each being the alias of an extension that you wish to load, or an empty list,
                which indicates that all extensions are to be run.
              • Services that use this:
                masakari-api
              • Related options:
                enabled, extensions_blacklist
   Deprecated Variations
                                         ┌──────────┬──────────────────────┐
                                         │ Group    │ Name                 │
                                         ├──────────┼──────────────────────┤
                                         │ osapi_v1 │ extensions_whitelist │
                                         └──────────┴──────────────────────┘
       WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
       project_id_regex
              Type   string
              Default
                     <None>
              DEPRECATED
              This  option  is a string representing a regular expression (regex) that matches the project_id as
              contained in URLs. If not set, it will match normal UUIDs created by keystone.
              • Possible values:
                A string representing any legal regular expression
              • Services that use this:
                masakari-api
              • Related options:
                None
   Deprecated Variations
                                           ┌──────────┬──────────────────┐
                                           │ Group    │ Name             │
                                           ├──────────┼──────────────────┤
                                           │ osapi_v1 │ project_id_regex │
                                           └──────────┴──────────────────┘
       WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
   oslo_messaging_kafka
       kafka_max_fetch_bytes
              Type   integer
              Default
                     1048576
              Max fetch bytes of Kafka consumer
       kafka_consumer_timeout
              Type   floating point
              Default
                     1.0
              Default timeout(s) for Kafka consumers
       consumer_group
              Type   string
              Default
                     oslo_messaging_consumer
              Group id for Kafka consumer. Consumers in one group will coordinate message consumption
       producer_batch_timeout
              Type   floating point
              Default
                     0.0
              Upper bound on the delay for KafkaProducer batching in seconds
       producer_batch_size
              Type   integer
              Default
                     16384
              Size of batch for the producer async send
       compression_codec
              Type   string
              Default
                     none
              Valid Values
                     none, gzip, snappy, lz4, zstd
              The compression codec for all data generated by the producer. If not set, compression will not  be
              used. Note that the allowed values of this depend on the kafka version
       enable_auto_commit
              Type   boolean
              Default
                     False
              Enable asynchronous consumer commits
       max_poll_records
              Type   integer
              Default
                     500
              The maximum number of records returned in a poll call
       security_protocol
              Type   string
              Default
                     PLAINTEXT
              Valid Values
                     PLAINTEXT, SASL_PLAINTEXT, SSL, SASL_SSL
              Protocol used to communicate with brokers
       sasl_mechanism
              Type   string
              Default
                     PLAIN
              Mechanism when security protocol is SASL
       ssl_cafile
              Type   string
              Default
                     ''
              CA certificate PEM file used to verify the server certificate
       ssl_client_cert_file
              Type   string
              Default
                     ''
              Client certificate PEM file used for authentication.
       ssl_client_key_file
              Type   string
              Default
                     ''
              Client key PEM file used for authentication.
       ssl_client_key_password
              Type   string
              Default
                     ''
              Client key password file used for authentication.
   oslo_messaging_notifications
       driver
              Type   multi-valued
              Default
                     ''
              The  Drivers(s)  to  handle  sending  notifications.  Possible  values are messaging, messagingv2,
              routing, log, test, noop
       transport_url
              Type   string
              Default
                     <None>
              A URL representing the messaging driver to use for notifications. If not set, we fall back to  the
              same configuration used for RPC.
       topics
              Type   list
              Default
                     ['notifications']
              AMQP topic used for OpenStack notifications.
       retry
              Type   integer
              Default
                     -1
              The  maximum number of attempts to re-send a notification message which failed to be delivered due
              to a recoverable error. 0 - No retry, -1 - indefinite
   oslo_messaging_rabbit
       amqp_durable_queues
              Type   boolean
              Default
                     False
              Use durable queues in AMQP. If rabbit_quorum_queue is enabled, queues will  be  durable  and  this
              value will be ignored.
       amqp_auto_delete
              Type   boolean
              Default
                     False
              Auto-delete queues in AMQP.
       rpc_conn_pool_size
              Type   integer
              Default
                     30
              Minimum Value
                     1
              Size of RPC connection pool.
       conn_pool_min_size
              Type   integer
              Default
                     2
              The pool size limit for connections expiration policy
       conn_pool_ttl
              Type   integer
              Default
                     1200
              The time-to-live in sec of idle connections in the pool
       ssl
              Type   boolean
              Default
                     False
              Connect over SSL.
       ssl_version
              Type   string
              Default
                     ''
              SSL  version  to use (valid only if SSL enabled). Valid values are TLSv1 and SSLv23. SSLv2, SSLv3,
              TLSv1_1, and TLSv1_2 may be available on some distributions.
       ssl_key_file
              Type   string
              Default
                     ''
              SSL key file (valid only if SSL enabled).
       ssl_cert_file
              Type   string
              Default
                     ''
              SSL cert file (valid only if SSL enabled).
       ssl_ca_file
              Type   string
              Default
                     ''
              SSL certification authority file (valid only if SSL enabled).
       ssl_enforce_fips_mode
              Type   boolean
              Default
                     False
              Global toggle for enforcing the OpenSSL FIPS mode. This feature requires Python support.  This  is
              available  in Python 3.9 in all environments and may have been backported to older Python versions
              on select environments. If the Python executable used does  not  support  OpenSSL  FIPS  mode,  an
              exception will be raised.
       heartbeat_in_pthread
              Type   boolean
              Default
                     False
              (DEPRECATED) It is recommend not to use this option anymore. Run the health check heartbeat thread
              through  a native python thread by default. If this option is equal to False then the health check
              heartbeat will inherit the execution model from the parent process.  For  example  if  the  parent
              process  has  monkey  patched the stdlib by using eventlet/greenlet then the heartbeat will be run
              through a green thread. This option should be set to True only for the wsgi services.
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason The option is related to Eventlet which will be removed.  In  addition  this  has  never
                        worked as expected with services using eventlet for core service framework.
       kombu_reconnect_delay
              Type   floating point
              Default
                     1.0
              Minimum Value
                     0.0
              Maximum Value
                     4.5
              How  long  to  wait  (in  seconds)  before  reconnecting  in  response  to an AMQP consumer cancel
              notification.
       kombu_reconnect_splay
              Type   floating point
              Default
                     0.0
              Minimum Value
                     0.0
              Random time to wait for when reconnecting in response to an AMQP consumer cancel notification.
       kombu_compression
              Type   string
              Default
                     <None>
              EXPERIMENTAL: Possible values are: gzip, bz2. If not set compression will not be used. This option
              may not be available in future versions.
       kombu_missing_consumer_retry_timeout
              Type   integer
              Default
                     60
              How long to wait a missing client before abandoning to send it its replies. This value should  not
              be longer than rpc_response_timeout.
   Deprecated Variations
                                 ┌───────────────────────┬─────────────────────────┐
                                 │ Group                 │ Name                    │
                                 ├───────────────────────┼─────────────────────────┤
                                 │ oslo_messaging_rabbit │ kombu_reconnect_timeout │
                                 └───────────────────────┴─────────────────────────┘
       kombu_failover_strategy
              Type   string
              Default
                     round-robin
              Valid Values
                     round-robin, shuffle
              Determines  how  the  next  RabbitMQ  node is chosen in case the one we are currently connected to
              becomes unavailable. Takes effect only if more than one RabbitMQ node is provided in config.
       rabbit_login_method
              Type   string
              Default
                     AMQPLAIN
              Valid Values
                     PLAIN, AMQPLAIN, EXTERNAL, RABBIT-CR-DEMO
              The RabbitMQ login method.
       rabbit_retry_interval
              Type   integer
              Default
                     1
              Minimum Value
                     1
              How frequently to retry connecting with RabbitMQ.
       rabbit_retry_backoff
              Type   integer
              Default
                     2
              Minimum Value
                     0
              How long to backoff for between retries when connecting to RabbitMQ.
       rabbit_interval_max
              Type   integer
              Default
                     30
              Minimum Value
                     1
              Maximum interval of RabbitMQ connection retries.
       rabbit_ha_queues
              Type   boolean
              Default
                     False
              Try to use HA queues in RabbitMQ (x-ha-policy: all). If you change this option, you must wipe  the
              RabbitMQ  database.  In  RabbitMQ  3.0, queue mirroring is no longer controlled by the x-ha-policy
              argument when declaring a queue. If you just want to make sure that all queues (except those  with
              auto-generated names) are mirrored across all nodes, run: “rabbitmqctl set_policy HA ‘^(?!amq.).*’
              ‘{“ha-mode”: “all”}’ “
       rabbit_quorum_queue
              Type   boolean
              Default
                     False
              Use  quorum queues in RabbitMQ (x-queue-type: quorum). The quorum queue is a modern queue type for
              RabbitMQ implementing a durable, replicated FIFO queue based on the Raft consensus  algorithm.  It
              is  available  as  of  RabbitMQ  3.8.0.  If  set  this  option  will  conflict  with the HA queues
              (rabbit_ha_queues) aka mirrored queues, in other words the HA queues should  be  disabled.  Quorum
              queues  are  also durable by default so the amqp_durable_queues option is ignored when this option
              is enabled.
       rabbit_transient_quorum_queue
              Type   boolean
              Default
                     False
              Use quorum queues for transients queues in RabbitMQ. Enabling this  option  will  then  make  sure
              those queues are also using quorum kind of rabbit queues, which are HA by default.
       rabbit_quorum_delivery_limit
              Type   integer
              Default
                     0
              Each  time  a  message is redelivered to a consumer, a counter is incremented. Once the redelivery
              count exceeds the delivery limit the message gets dropped or dead-lettered (if a DLX exchange  has
              been  configured)  Used only when rabbit_quorum_queue is enabled, Default 0 which means dont set a
              limit.
       rabbit_quorum_max_memory_length
              Type   integer
              Default
                     0
              By default all messages are maintained in memory if a quorum queue grows  in  length  it  can  put
              memory  pressure  on  a cluster. This option can limit the number of messages in the quorum queue.
              Used only when rabbit_quorum_queue is enabled, Default 0 which means dont set a limit.
   Deprecated Variations
                             ┌───────────────────────┬─────────────────────────────────┐
                             │ Group                 │ Name                            │
                             ├───────────────────────┼─────────────────────────────────┤
                             │ oslo_messaging_rabbit │ rabbit_quroum_max_memory_length │
                             └───────────────────────┴─────────────────────────────────┘
       rabbit_quorum_max_memory_bytes
              Type   integer
              Default
                     0
              By default all messages are maintained in memory if a quorum queue grows  in  length  it  can  put
              memory  pressure on a cluster. This option can limit the number of memory bytes used by the quorum
              queue. Used only when rabbit_quorum_queue is enabled, Default 0 which means dont set a limit.
   Deprecated Variations
                              ┌───────────────────────┬────────────────────────────────┐
                              │ Group                 │ Name                           │
                              ├───────────────────────┼────────────────────────────────┤
                              │ oslo_messaging_rabbit │ rabbit_quroum_max_memory_bytes │
                              └───────────────────────┴────────────────────────────────┘
       rabbit_transient_queues_ttl
              Type   integer
              Default
                     1800
              Minimum Value
                     0
              Positive integer representing duration in seconds for queue  TTL  (x-expires).  Queues  which  are
              unused for the duration of the TTL are automatically deleted. The parameter affects only reply and
              fanout  queues.  Setting  0 as value will disable the x-expires. If doing so, make sure you have a
              rabbitmq policy to delete the queues or you deployment will create an  infinite  number  of  queue
              over  time.In  case  rabbit_stream_fanout  is set to True, this option will control data retention
              policy (x-max-age) for messages in the fanout queue rather then the queue duration itself. So  the
              oldest  data  in  the  stream  queue will be discarded from it once reaching TTL Setting to 0 will
              disable x-max-age for stream which make stream grow indefinitely filling up the diskspace
       rabbit_qos_prefetch_count
              Type   integer
              Default
                     0
              Specifies the number of messages to prefetch. Setting to zero allows unlimited messages.
       heartbeat_timeout_threshold
              Type   integer
              Default
                     60
              Number of seconds after which the Rabbit broker is considered down if heartbeat’s keep-alive fails
              (0 disables heartbeat).
       heartbeat_rate
              Type   integer
              Default
                     3
              How often times during the heartbeat_timeout_threshold we check the heartbeat.
       direct_mandatory_flag
              Type   boolean
              Default
                     True
              (DEPRECATED) Enable/Disable the RabbitMQ mandatory flag for direct send. The direct send  is  used
              as  reply,  so  the  MessageUndeliverable  exception  is  raised in case the client queue does not
              exist.MessageUndeliverable exception will be used to loop for a timeout to lets a chance to sender
              to recover.This flag is deprecated and it will not be possible to  deactivate  this  functionality
              anymore
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason Mandatory flag no longer deactivable.
       enable_cancel_on_failover
              Type   boolean
              Default
                     False
              Enable  x-cancel-on-ha-failover  flag so that rabbitmq server will cancel and notify consumerswhen
              queue is down
       use_queue_manager
              Type   boolean
              Default
                     False
              Should we use consistant queue names or random ones
       hostname
              Type   string
              Default
                     node1.example.com
              This option has a sample default set, which means that its actual default value may vary from  the
              one documented above.
              Hostname used by queue manager. Defaults to the value returned by socket.gethostname().
       processname
              Type   string
              Default
                     nova-api
              This  option has a sample default set, which means that its actual default value may vary from the
              one documented above.
              Process name used by queue manager
       rabbit_stream_fanout
              Type   boolean
              Default
                     False
              Use stream queues in RabbitMQ (x-queue-type: stream). Streams are a new persistent and  replicated
              data  structure  (“queue  type”)  in RabbitMQ which models an append-only log with non-destructive
              consumer semantics. It is available as of RabbitMQ 3.9.0. If set  this  option  will  replace  all
              fanout queues with only one stream queue.
   oslo_middleware
       max_request_body_size
              Type   integer
              Default
                     114688
              The maximum body size for each  request, in bytes.
   Deprecated Variations
                                      ┌─────────┬─────────────────────────────┐
                                      │ Group   │ Name                        │
                                      ├─────────┼─────────────────────────────┤
                                      │ DEFAULT │ osapi_max_request_body_size │
                                      ├─────────┼─────────────────────────────┤
                                      │ DEFAULT │ max_request_body_size       │
                                      └─────────┴─────────────────────────────┘
       enable_proxy_headers_parsing
              Type   boolean
              Default
                     False
              Whether  the  application is behind a proxy or not. This determines if the middleware should parse
              the headers or not.
       http_basic_auth_user_file
              Type   string
              Default
                     /etc/htpasswd
              HTTP basic auth password file.
   oslo_policy
       enforce_scope
              Type   boolean
              Default
                     True
              This option controls whether or not to enforce scope when evaluating policies. If True, the  scope
              of  the  token used in the request is compared to the scope_types of the policy being enforced. If
              the scopes do not match, an InvalidScope exception will be raised. If False,  a  message  will  be
              logged informing operators that policies are being invoked with mismatching scope.
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason This  configuration  was  added temporarily to facilitate a smooth transition to the new
                        RBAC.  OpenStack  will  always  enforce  scope  checks.  This  configuration  option  is
                        deprecated and will be removed in the 2025.2 cycle.
       enforce_new_defaults
              Type   boolean
              Default
                     True
              This  option  controls  whether or not to use old deprecated defaults when evaluating policies. If
              True, the old deprecated defaults are not going to be evaluated. This means if any existing  token
              is  allowed  for  old  defaults  but  is disallowed for new defaults, it will be disallowed. It is
              encouraged to enable this flag along with the enforce_scope flag so that you can get the  benefits
              of new defaults and scope_type together. If False, the deprecated policy check string is logically
              OR’d with the new policy check string, allowing for a graceful upgrade experience between releases
              with new policies, which is the default behavior.
       policy_file
              Type   string
              Default
                     policy.yaml
              The  relative  or  absolute  path  of  a  file that maps roles to permissions for a given service.
              Relative paths must be specified in relation to the configuration file setting this option.
       policy_default_rule
              Type   string
              Default
                     default
              Default rule. Enforced when a requested rule is not found.
       policy_dirs
              Type   multi-valued
              Default
                     policy.d
              Directories where policy configuration files are stored. They can be relative to any directory  in
              the  search  path  defined  by  the  config_dir  option,  or  absolute  paths. The file defined by
              policy_file must exist for these directories to be searched.  Missing  or  empty  directories  are
              ignored.
       remote_content_type
              Type   string
              Default
                     application/x-www-form-urlencoded
              Valid Values
                     application/x-www-form-urlencoded, application/json
              Content Type to send and receive data for REST based policy check
       remote_ssl_verify_server_crt
              Type   boolean
              Default
                     False
              server identity verification for REST based policy check
       remote_ssl_ca_crt_file
              Type   string
              Default
                     <None>
              Absolute path to ca cert file for REST based policy check
       remote_ssl_client_crt_file
              Type   string
              Default
                     <None>
              Absolute path to client cert for REST based policy check
       remote_ssl_client_key_file
              Type   string
              Default
                     <None>
              Absolute path client key file REST based policy check
       remote_timeout
              Type   floating point
              Default
                     60
              Minimum Value
                     0
              Timeout in seconds for REST based policy check
   oslo_versionedobjects
       fatal_exception_format_errors
              Type   boolean
              Default
                     False
              Make exception message format errors fatal
   process_failure
       service_disable_reason
              Type   string
              Default
                     Masakari detected process failed.
              Compute disable reason in case Masakari detects process failure.
   ssl
       ca_file
              Type   string
              Default
                     <None>
              CA certificate file to use to verify connecting clients.
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason The ‘ca_file’ option is deprecated and will be removed in a future release.
       cert_file
              Type   string
              Default
                     <None>
              Certificate file to use when starting the server securely.
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason The ‘cert_file’ option is deprecated and will be removed in a future release.
       key_file
              Type   string
              Default
                     <None>
              Private key file to use when starting the server securely.
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason The ‘key_file’ option is deprecated and will be removed in a future release.
       version
              Type   string
              Default
                     <None>
              SSL  version  to use (valid only if SSL enabled). Valid values are TLSv1 and SSLv23. SSLv2, SSLv3,
              TLSv1_1, and TLSv1_2 may be available on some distributions.
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason The ‘version’ option is deprecated and will be removed in a future release.
       ciphers
              Type   string
              Default
                     <None>
              Sets the list of available ciphers. value should be a string in the OpenSSL cipher list format.
              WARNING:
                 This option is deprecated for removal.  Its value may be silently ignored in the future.
                 Reason The ‘ciphers’ option is deprecated and will be removed in a future release.
   taskflow
       connection
              Type   string
              Default
                     <None>
              The SQLAlchemy connection string to use to connect to the taskflow database.
   wsgi
       api_paste_config
              Type   string
              Default
                     api-paste.ini
              File name for the paste.deploy config for masakari-api
   Deprecated Variations
                                            ┌─────────┬──────────────────┐
                                            │ Group   │ Name             │
                                            ├─────────┼──────────────────┤
                                            │ DEFAULT │ api_paste_config │
                                            └─────────┴──────────────────┘
       wsgi_log_format
              Type   string
              Default
                     %(client_ip)s  "%(request_line)s"  status:  %(status_code)s  len:   %(body_length)s   time:
                     %(wall_seconds).7f
              A  python  format  string that is used as the template to generate log lines. The following values
              can  be  formatted  into  it:  client_ip,  date_time,  request_line,   status_code,   body_length,
              wall_seconds.
   Deprecated Variations
                                            ┌─────────┬─────────────────┐
                                            │ Group   │ Name            │
                                            ├─────────┼─────────────────┤
                                            │ DEFAULT │ wsgi_log_format │
                                            └─────────┴─────────────────┘
       secure_proxy_ssl_header
              Type   string
              Default
                     <None>
              The  HTTP  header used to determine the scheme for the original request, even if it was removed by
              an SSL terminating proxy. Typical value is “HTTP_X_FORWARDED_PROTO”.
   Deprecated Variations
                                        ┌─────────┬─────────────────────────┐
                                        │ Group   │ Name                    │
                                        ├─────────┼─────────────────────────┤
                                        │ DEFAULT │ secure_proxy_ssl_header │
                                        └─────────┴─────────────────────────┘
       ssl_ca_file
              Type   string
              Default
                     <None>
              CA certificate file to use to verify connecting clients
   Deprecated Variations
                                              ┌─────────┬─────────────┐
                                              │ Group   │ Name        │
                                              ├─────────┼─────────────┤
                                              │ DEFAULT │ ssl_ca_file │
                                              └─────────┴─────────────┘
       ssl_cert_file
              Type   string
              Default
                     <None>
              SSL certificate of API server
   Deprecated Variations
                                             ┌─────────┬───────────────┐
                                             │ Group   │ Name          │
                                             ├─────────┼───────────────┤
                                             │ DEFAULT │ ssl_cert_file │
                                             └─────────┴───────────────┘
       ssl_key_file
              Type   string
              Default
                     <None>
              SSL private key of API server
   Deprecated Variations
                                              ┌─────────┬──────────────┐
                                              │ Group   │ Name         │
                                              ├─────────┼──────────────┤
                                              │ DEFAULT │ ssl_key_file │
                                              └─────────┴──────────────┘
       tcp_keepidle
              Type   integer
              Default
                     600
              Sets the value of TCP_KEEPIDLE in seconds for each server socket. Not supported on OS X.
   Deprecated Variations
                                              ┌─────────┬──────────────┐
                                              │ Group   │ Name         │
                                              ├─────────┼──────────────┤
                                              │ DEFAULT │ tcp_keepidle │
                                              └─────────┴──────────────┘
       default_pool_size
              Type   integer
              Default
                     1000
              Size of the pool of greenthreads used by wsgi
   Deprecated Variations
                                         ┌─────────┬────────────────────────┐
                                         │ Group   │ Name                   │
                                         ├─────────┼────────────────────────┤
                                         │ DEFAULT │ wsgi_default_pool_size │
                                         └─────────┴────────────────────────┘
       max_header_line
              Type   integer
              Default
                     16384
              Maximum line size of message headers to be accepted. max_header_line may need to be increased when
              using large tokens (typically those generated by the Keystone v3 API with big service catalogs).
   Deprecated Variations
                                            ┌─────────┬─────────────────┐
                                            │ Group   │ Name            │
                                            ├─────────┼─────────────────┤
                                            │ DEFAULT │ max_header_line │
                                            └─────────┴─────────────────┘
       keep_alive
              Type   boolean
              Default
                     True
              If False, closes the client socket connection explicitly.
   Deprecated Variations
                                            ┌─────────┬─────────────────┐
                                            │ Group   │ Name            │
                                            ├─────────┼─────────────────┤
                                            │ DEFAULT │ wsgi_keep_alive │
                                            └─────────┴─────────────────┘
       client_socket_timeout
              Type   integer
              Default
                     900
              Timeout for client connections’ socket operations. If an incoming  connection  is  idle  for  this
              number of seconds it will be closed. A value of ‘0’ means wait forever.
   Deprecated Variations
                                         ┌─────────┬───────────────────────┐
                                         │ Group   │ Name                  │
                                         ├─────────┼───────────────────────┤
                                         │ DEFAULT │ client_socket_timeout │
                                         └─────────┴───────────────────────┘
   Configuration Guide
       The configuration for masakari lies in below described files.
   Configuration
       Masakari has two main config files: masakari.conf and recovery_workflow_sample_config.conf.
       • Config Reference: A complete reference of all config points in masakari and what they impact.
       • Recovery Config Reference: A complete reference of all config points in masakari and what they impact.
   Policy
       Masakari,  like  most  OpenStack  projects,  uses  a  policy language to restrict permissions on REST API
       actions.
       • Policy Reference: A complete reference of all policy points in masakari and what they impact.
       • Sample policy File: A sample policy file with inline documentation.
   API configuration settings
       • API configuration: A complete reference of API configuration settings.
   Masakari Policies
       WARNING:
          JSON  formatted   policy   file   is   deprecated   since   Masakari   11.0.0   (Wallaby).    This   ‐
          oslopolicy-convert-json-to-yaml  tool will migrate your existing JSON-formatted policy file to YAML in
          a backward-compatible way.
       The following is an overview of all available policies in masakari.  For  a  sample  configuration  file,
       refer to Sample Masakari Policy File.
   masakari
       context_is_admin
              Default
                     role:admin
              Decides what is required for the ‘is_admin:True’ check to succeed.
       admin_or_owner
              Default
                     is_admin:True or project_id:%(project_id)s
              Default rule for most non-Admin APIs.
       admin_api
              Default
                     is_admin:True
              Default rule for most Admin APIs.
       os_masakari_api:extensions:index
              Default
                     rule:admin_api
              Operations
                     • GET /extensions
              List available extensions.
       os_masakari_api:extensions:detail
              Default
                     rule:admin_api
              Operations
                     • GET /extensions/{extensions_id}
              Shows information for an extension.
       os_masakari_api:extensions:discoverable
              Default
                     rule:admin_api
              Extension Info API extensions to change the API.
       os_masakari_api:os-hosts:index
              Default
                     rule:admin_api
              Operations
                     • GET /segments/{segment_id}/hosts
              Lists IDs, names, type, reserved, on_maintenance for all hosts.
       os_masakari_api:os-hosts:detail
              Default
                     rule:admin_api
              Operations
                     • GET /segments/{segment_id}/hosts/{host_id}
              Shows details for a host.
       os_masakari_api:os-hosts:create
              Default
                     rule:admin_api
              Operations
                     • POST /segments/{segment_id}/hosts
              Creates a host under given segment.
       os_masakari_api:os-hosts:update
              Default
                     rule:admin_api
              Operations
                     • PUT /segments/{segment_id}/hosts/{host_id}
              Updates the editable attributes of an existing host.
       os_masakari_api:os-hosts:delete
              Default
                     rule:admin_api
              Operations
                     • DELETE /segments/{segment_id}/hosts/{host_id}
              Deletes a host from given segment.
       os_masakari_api:os-hosts:discoverable
              Default
                     rule:admin_api
              Host API extensions to change the API.
       os_masakari_api:notifications:index
              Default
                     rule:admin_api
              Operations
                     • GET /notifications
              Lists   IDs,   notification   types,   host_name,  generated_time,  payload  and  status  for  all
              notifications.
       os_masakari_api:notifications:detail
              Default
                     rule:admin_api
              Operations
                     • GET /notifications/{notification_id}
              Shows details for a notification.
       os_masakari_api:notifications:create
              Default
                     rule:admin_api
              Operations
                     • POST /notifications
              Creates a notification.
       os_masakari_api:notifications:discoverable
              Default
                     rule:admin_api
              Notification API extensions to change the API.
       os_masakari_api:segments:index
              Default
                     rule:admin_api
              Operations
                     • GET /segments
              Lists IDs, names, description, recovery_method, service_type for all segments.
       os_masakari_api:segments:detail
              Default
                     rule:admin_api
              Operations
                     • GET /segments/{segment_id}
              Shows details for a segment.
       os_masakari_api:segments:create
              Default
                     rule:admin_api
              Operations
                     • POST /segments
              Creates a segment.
       os_masakari_api:segments:update
              Default
                     rule:admin_api
              Operations
                     • PUT /segments/{segment_id}
              Updates the editable attributes of an existing host.
       os_masakari_api:segments:delete
              Default
                     rule:admin_api
              Operations
                     • DELETE /segments/{segment_id}
              Deletes a segment.
       os_masakari_api:segments:discoverable
              Default
                     rule:admin_api
              Segment API extensions to change the API.
       os_masakari_api:versions:index
              Default
                     @
              Operations
                     • GET /
              List all versions.
       os_masakari_api:versions:discoverable
              Default
                     @
              Version API extensions to change the API.
       os_masakari_api:vmoves:index
              Default
                     rule:admin_api
              Operations
                     • GET /notifications/{notification_id}/vmoves
              Lists IDs, notification_id, instance_id, source_host, dest_host, status and type for all VM moves.
       os_masakari_api:vmoves:detail
              Default
                     rule:admin_api
              Operations
                     • GET /notifications/{notification_id}/vmoves/{vmove_id}
              Shows details for one VM move.
       os_masakari_api:vmoves:discoverable
              Default
                     rule:admin_api
              VM moves API extensions to change the API.
   Configuration Options
       The following is an overview of all available configuration options in Masakari.
   taskflow_driver_recovery_flows
       host_auto_failure_recovery_tasks
              Type   unknown type
              Default
                     {'pre':  ['disable_compute_service_task'],  'main':  ['prepare_HA_enabled_instances_task'],
                     'post': ['evacuate_instances_task']}
              This  option  allows  operator  to  customize  tasks to be executed for host failure auto recovery
              workflow.
              Provide list of strings reflecting to the task classes that should be included to the host failure
              recovery workflow. The full  classname  path  of  all  task  classes  should  be  defined  in  the
              ‘masakari.task_flow.tasks’  of  setup.cfg  and  these  classes  may  be  implemented  by OpenStack
              Masaskari project team, deployer or third party.
              By default below three tasks will be part of this config option:- 1.  disable_compute_service_task
              2. prepare_HA_enabled_instances_task 3. evacuate_instances_task
              The  allowed values for this option is comma separated dictionary of object names in between { and
              }.
       host_rh_failure_recovery_tasks
              Type   unknown type
              Default
                     {'pre':  ['disable_compute_service_task'],  'main':   ['prepare_HA_enabled_instances_task',
                     'evacuate_instances_task'], 'post': []}
              This  option  allows  operator  to  customize  tasks to be executed for host failure reserved_host
              recovery workflow.
              Provide list of strings reflecting to the task classes that should be included to the host failure
              recovery workflow. The full  classname  path  of  all  task  classes  should  be  defined  in  the
              ‘masakari.task_flow.tasks’  of  setup.cfg  and  these  classes  may  be  implemented  by OpenStack
              Masaskari project team, deployer or third party.
              By default below three tasks will be part of this config option:- 1.  disable_compute_service_task
              2. prepare_HA_enabled_instances_task 3. evacuate_instances_task
              The  allowed values for this option is comma separated dictionary of object names in between { and
              }.
       instance_failure_recovery_tasks
              Type   unknown type
              Default
                     {'pre':     ['stop_instance_task'],      'main':      ['start_instance_task'],      'post':
                     ['confirm_instance_active_task']}
              This  option  allows  operator  to  customize  tasks  to be executed for instance failure recovery
              workflow.
              Provide list of strings reflecting to the task classes that should be  included  to  the  instance
              failure  recovery  workflow.  The full classname path of all task classes should be defined in the
              ‘masakari.task_flow.tasks’ of  setup.cfg  and  these  classes  may  be  implemented  by  OpenStack
              Masaskari project team, deployer or third party.
              By  default  below  three  tasks  will  be  part  of this config option:- 1. stop_instance_task 2.
              start_instance_task 3. confirm_instance_active_task
              The allowed values for this option is comma separated dictionary of object names in between {  and
              }.
       process_failure_recovery_tasks
              Type   unknown type
              Default
                     {'pre':   ['disable_compute_node_task'],   'main':  ['confirm_compute_node_disabled_task'],
                     'post': []}
              This option allows operator to customize  tasks  to  be  executed  for  process  failure  recovery
              workflow.
              Provide  list  of  strings  reflecting  to the task classes that should be included to the process
              failure recovery workflow. The full classname path of all task classes should be  defined  in  the
              ‘masakari.task_flow.tasks’  of  setup.cfg  and  these  classes  may  be  implemented  by OpenStack
              Masaskari project team, deployer or third party.
              By default below two tasks will be part of this config option:-  1.  disable_compute_node_task  2.
              confirm_compute_node_disabled_task
              The  allowed values for this option is comma separated dictionary of object names in between { and
              }.
   Guide for Custom Recovery Workflow Configuration
       If operator wants customized recovery workflow, so here is guidelines  mentioned  for  how  to  associate
       custom tasks from Third Party Library along with standard recovery workflows in Masakari.:
       1. First  make  sure  required Third Party Library is installed on the Masakari engine node. Below is the
          sample custom task file.  For example:
          from oslo_log import log as logging
          from taskflow import task
          LOG = logging.getLogger(__name__)
          class Noop(task.Task):
              def __init__(self, novaclient):
                  self.novaclient = novaclient
                  super(Noop, self).__init__()
              def execute(self, **kwargs):
                  LOG.info("Custom task executed successfully..!!")
                  return
       1. Configure custom task in Third Party Library’s setup.cfg as below:
       For example, Third Party Library’s setup.cfg will have following entry points
          masakari.task_flow.tasks =
              custom_pre_task = <custom_task_class_path_from_third_party_library>
              custom_main_task = <custom_task_class_path_from_third_party_library>
              custom_post_task = <custom_task_class_path_from_third_party_library>
       Note: Entry point in Third Party Library’s setup.cfg should have same key as in  Masakari  setup.cfg  for
       respective failure recovery.
       1. Configure  custom  task  in Masakari’s new conf file custom-recovery-methods.conf with same name which
          was given in the setup.cfg to locate class path.  For example(custom task added in host  auto  failure
          config option):
          host_auto_failure_recovery_tasks = {
          'pre': ['disable_compute_service_task', 'custom_pre_task'],
          'main': ['custom_main_task', 'prepare_HA_enabled_instances_task'],
          'post': ['evacuate_instances_task', 'custom_post_task']}
       1. If   there   are   any  configuration  parameters  required  for  custom  task,  then  add  them  into
          custom-recovery-methods.conf under the same group/section where they are  registered  in  Third  Party
          Library.  All config parameters related to recovery method customization should be part of newly added
          conf  file.  Operator will be responsible to generate masakari.conf and related configuration files by
          themselves.
       2. Operator should ensure output of each task should be made available to the next tasks needing them.
   Sample Masakari Policy File
       WARNING:
          JSON  formatted   policy   file   is   deprecated   since   Masakari   11.0.0   (Wallaby).    This   ‐
          oslopolicy-convert-json-to-yaml  tool will migrate your existing JSON-formatted policy file to YAML in
          a backward-compatible way.
       The following is a sample masakari policy file for adaptation and use.
       The sample policy can also be viewed in file form.
       IMPORTANT:
          The sample policy file is auto-generated from masakari when this documentation is built.
          # Decides what is required for the 'is_admin:True' check to succeed.
          #"context_is_admin": "role:admin"
          # Default rule for most non-Admin APIs.
          #"admin_or_owner": "is_admin:True or project_id:%(project_id)s"
          # Default rule for most Admin APIs.
          #"admin_api": "is_admin:True"
          # List available extensions.
          # GET  /extensions
          #"os_masakari_api:extensions:index": "rule:admin_api"
          # Shows information for an extension.
          # GET  /extensions/{extensions_id}
          #"os_masakari_api:extensions:detail": "rule:admin_api"
          # Extension Info API extensions to change the API.
          #"os_masakari_api:extensions:discoverable": "rule:admin_api"
          # Lists IDs, names, type, reserved, on_maintenance for all hosts.
          # GET  /segments/{segment_id}/hosts
          #"os_masakari_api:os-hosts:index": "rule:admin_api"
          # Shows details for a host.
          # GET  /segments/{segment_id}/hosts/{host_id}
          #"os_masakari_api:os-hosts:detail": "rule:admin_api"
          # Creates a host under given segment.
          # POST  /segments/{segment_id}/hosts
          #"os_masakari_api:os-hosts:create": "rule:admin_api"
          # Updates the editable attributes of an existing host.
          # PUT  /segments/{segment_id}/hosts/{host_id}
          #"os_masakari_api:os-hosts:update": "rule:admin_api"
          # Deletes a host from given segment.
          # DELETE  /segments/{segment_id}/hosts/{host_id}
          #"os_masakari_api:os-hosts:delete": "rule:admin_api"
          # Host API extensions to change the API.
          #"os_masakari_api:os-hosts:discoverable": "rule:admin_api"
          # Lists IDs, notification types, host_name, generated_time, payload
          # and status for all notifications.
          # GET  /notifications
          #"os_masakari_api:notifications:index": "rule:admin_api"
          # Shows details for a notification.
          # GET  /notifications/{notification_id}
          #"os_masakari_api:notifications:detail": "rule:admin_api"
          # Creates a notification.
          # POST  /notifications
          #"os_masakari_api:notifications:create": "rule:admin_api"
          # Notification API extensions to change the API.
          #"os_masakari_api:notifications:discoverable": "rule:admin_api"
          # Lists IDs, names, description, recovery_method, service_type for all
          # segments.
          # GET  /segments
          #"os_masakari_api:segments:index": "rule:admin_api"
          # Shows details for a segment.
          # GET  /segments/{segment_id}
          #"os_masakari_api:segments:detail": "rule:admin_api"
          # Creates a segment.
          # POST  /segments
          #"os_masakari_api:segments:create": "rule:admin_api"
          # Updates the editable attributes of an existing host.
          # PUT  /segments/{segment_id}
          #"os_masakari_api:segments:update": "rule:admin_api"
          # Deletes a segment.
          # DELETE  /segments/{segment_id}
          #"os_masakari_api:segments:delete": "rule:admin_api"
          # Segment API extensions to change the API.
          #"os_masakari_api:segments:discoverable": "rule:admin_api"
          # List all versions.
          # GET  /
          #"os_masakari_api:versions:index": "@"
          # Version API extensions to change the API.
          #"os_masakari_api:versions:discoverable": "@"
          # Lists IDs, notification_id, instance_id, source_host, dest_host,
          # status and type for all VM moves.
          # GET  /notifications/{notification_id}/vmoves
          #"os_masakari_api:vmoves:index": "rule:admin_api"
          # Shows details for one VM move.
          # GET  /notifications/{notification_id}/vmoves/{vmove_id}
          #"os_masakari_api:vmoves:detail": "rule:admin_api"
          # VM moves API extensions to change the API.
          #"os_masakari_api:vmoves:discoverable": "rule:admin_api"
   Masakari System Architecture
       Masakari comprises of two services api and engine, each performing different functions.  The  user-facing
       interface is a REST API, while internally Masakari communicates via an RPC message passing mechanism.
       The  API  servers  process  REST  requests,  which  typically  involve database reads/writes, sending RPC
       messages to other Masakari engine, and generating responses to the REST calls.  RPC messaging is done via
       the oslo.messaging library, an abstraction on top of message queues.  The Masakari engine will run on the
       same host where the Masakari api is running, and has a manager that is listening for RPC  messages.   The
       manager too has periodic tasks.
   Components
       Below  you  will  find  a  helpful  explanation  of  the key components of a typical Masakari deployment.
       [image]
       • DB: sql database for data storage.
       • API: component that receives HTTP requests, converts commands and communicates with masakari engine via
         the oslo.messaging queue.
       • Engine: Executes recovery workflow and communicates with nova via HTTP.
   Notifications in Masakari
       Similar to other OpenStack services Masakari emits notifications to the message  bus  with  the  Notifier
       class  provided  by oslo.messaging.  From the notification consumer point of view a notification consists
       of two parts: an envelope with a fixed structure defined by oslo.messaging and a payload defined  by  the
       service emitting the notification.  The envelope format is the following:
          {
              "priority": <string, selected from a predefined list by the sender>,
              "event_type": <string, defined by the sender>,
              "timestamp": <string, the isotime of when the notification emitted>,
              "publisher_id": <string, defined by the sender>,
              "message_id": <uuid, generated by oslo>,
              "payload": <json serialized dict, defined by the sender>
          }
       oslo.messaging provides below choices of notification drivers:
                                   ┌─────────────┬───────────────────────────────────────┐
                                   │ Driver      │ Description                           │
                                   ├─────────────┼───────────────────────────────────────┤
                                   │ messaging   │ Send   notifications  using  the  1.0 │
                                   │             │ message format                        │
                                   ├─────────────┼───────────────────────────────────────┤
                                   │ messagingv2 │ Send  notifications  using  the   2.0 │
                                   │             │ message   format   (with   a  message │
                                   │             │ envelope)                             │
                                   ├─────────────┼───────────────────────────────────────┤
                                   │ routing     │ Configurable  routing  notifier   (by │
                                   │             │ priority or event_type)               │
                                   ├─────────────┼───────────────────────────────────────┤
                                   │ log         │ Publish   notifications   via  Python │
                                   │             │ logging infrastructure                │
                                   ├─────────────┼───────────────────────────────────────┤
                                   │ test        │ Store  notifications  in  memory  for │
                                   │             │ test verification                     │
                                   ├─────────────┼───────────────────────────────────────┤
                                   │ noop        │ Disable     sending     notifications │
                                   │             │ entirely                              │
                                   └─────────────┴───────────────────────────────────────┘
       So notifications can be completely disabled by setting the following in Masakari configuration file:
          [oslo_messaging_notifications]
          driver = noop
       Masakari supports only Versioned notifications.
   Versioned notifications
       Masakari code uses the masakari.rpc.get_notifier call to get a configured oslo.messaging Notifier  object
       and  it  uses the oslo provided functions on the Notifier object to emit notifications. The configuration
       of the returned Notifier object depends on the parameters of the get_notifier call and the value  of  the
       oslo.messaging configuration options driver and topics.  The versioned notification payload is not a free
       form dictionary but a serialized oslo.versionedobjects.
       For example the wire format of the segment.update notification looks like the following:
          {
              "event_type": "api.update.segments.start",
              "timestamp": "2018-11-27 14:32:20.396940",
              "payload": {
                  "masakari_object.name": "SegmentApiPayload",
                  "masakari_object.data": {
                      "description": null,
                      "fault": null,
                      "recovery_method": "auto",
                      "name": "test",
                      "service_type": "compute",
                      "id": 877,
                      "uuid": "89597691-bebd-4860-a93e-1b6e9de34b9e"
                  }, "
                  "masakari_object.version": "1.0",
                  "masakari_object.namespace": "masakari"
              },
              "priority": "INFO",
              "publisher_id": "masakari-api:test-virtualbox",
              "message_id": "e6322900-025d-4dd6-a3a1-3e0e1e9badeb"
          }
       The  serialized  oslo  versionedobject  as  a  payload  provides  a version number to the consumer so the
       consumer can detect if the structure of the payload is changed. Masakari provides the following  contract
       regarding the versioned notification payload:
       • the  payload version defined by the masakari_object.version field of the payload will be increased only
         if the syntax or the semantics of the masakari_object.data field of the payload is changed.
       • a minor version bump indicates a backward compatible change which means that only new fields are  added
         to the payload so a well written consumer can still consume the new payload without any change.
       • a  major  version  bump  indicates a backward incompatible change of the payload which can mean removed
         fields, type change, etc in the payload.
       • there is an additional field masakari_object.name for every payload  besides  masakari_object.data  and
         masakari_object.version.   This  field contains the name of the Masakari internal representation of the
         payload type. Client code should not depend on this name.
   Existing versioned notifications
       • This provides the list of existing versioned notifications with sample payloads.
            ┌────────────────────────────┬─────────────────────────────┬────────────────────────┬────────┐
            │ Event type                 │ Notification class          │ Payload class          │ Sample │
            ├────────────────────────────┼─────────────────────────────┼────────────────────────┼────────┤
            │ error.exception            │ ExceptionNotification       │ ExceptionPayload       │        │
            ├────────────────────────────┼─────────────────────────────┼────────────────────────┼────────┤
            │ create.host.end            │ HostApiNotification         │ HostApiPayload         │        │
            ├────────────────────────────┼─────────────────────────────┼────────────────────────┼────────┤
            │ create.host.start          │ HostApiNotification         │ HostApiPayload         │        │
            ├────────────────────────────┼─────────────────────────────┼────────────────────────┼────────┤
            │ delete.host.end            │ HostApiNotification         │ HostApiPayload         │        │
            ├────────────────────────────┼─────────────────────────────┼────────────────────────┼────────┤
            │ delete.host.start          │ HostApiNotification         │ HostApiPayload         │        │
            ├────────────────────────────┼─────────────────────────────┼────────────────────────┼────────┤
            │ update.host.end            │ HostApiNotification         │ HostApiPayload         │        │
            ├────────────────────────────┼─────────────────────────────┼────────────────────────┼────────┤
            │ update.host.start          │ HostApiNotification         │ HostApiPayload         │        │
            ├────────────────────────────┼─────────────────────────────┼────────────────────────┼────────┤
            │ create.notification.end    │ NotificationApiNotification │ NotificationApiPayload │        │
            ├────────────────────────────┼─────────────────────────────┼────────────────────────┼────────┤
            │ create.notification.start  │ NotificationApiNotification │ NotificationApiPayload │        │
            ├────────────────────────────┼─────────────────────────────┼────────────────────────┼────────┤
            │ process.notification.end   │ NotificationApiNotification │ NotificationApiPayload │        │
            ├────────────────────────────┼─────────────────────────────┼────────────────────────┼────────┤
            │ process.notification.error │ NotificationApiNotification │ NotificationApiPayload │        │
            ├────────────────────────────┼─────────────────────────────┼────────────────────────┼────────┤
            │ process.notification.start │ NotificationApiNotification │ NotificationApiPayload │        │
            ├────────────────────────────┼─────────────────────────────┼────────────────────────┼────────┤
            │ create.segment.end         │ SegmentApiNotification      │ SegmentApiPayload      │        │
            ├────────────────────────────┼─────────────────────────────┼────────────────────────┼────────┤
            │ create.segment.start       │ SegmentApiNotification      │ SegmentApiPayload      │        │
            ├────────────────────────────┼─────────────────────────────┼────────────────────────┼────────┤
            │ delete.segment.end         │ SegmentApiNotification      │ SegmentApiPayload      │        │
            ├────────────────────────────┼─────────────────────────────┼────────────────────────┼────────┤
            │ delete.segment.start       │ SegmentApiNotification      │ SegmentApiPayload      │        │
            ├────────────────────────────┼─────────────────────────────┼────────────────────────┼────────┤
            │ update.segment.end         │ SegmentApiNotification      │ SegmentApiPayload      │        │
            ├────────────────────────────┼─────────────────────────────┼────────────────────────┼────────┤
            │ update.segment.start       │ SegmentApiNotification      │ SegmentApiPayload      │        │
            └────────────────────────────┴─────────────────────────────┴────────────────────────┴────────┘
AUTHOR
       Author name not set
COPYRIGHT
       2016, OpenStack Foundation
19.0.0                                            Apr 03, 2025                                       MASAKARI(1)