Browse Source

Support to configure [api_database] parameters

Change-Id: I3d086a0b7860590d6cdef8074ce201b7e10f3cb5
(cherry picked from commit 8c313ebdb9)
changes/17/761117/1
Rocky 9 months ago
parent
commit
142622e6b7
  1. 99
      manifests/db.pp
  2. 11
      releasenotes/notes/add_api_database_parameters-bab34198427af74b.yaml
  3. 80
      spec/classes/nova_db_spec.rb

99
manifests/db.pp

@ -21,11 +21,6 @@
#
# == Parameters
#
# [*database_db_max_retries*]
# (optional) Maximum retries in case of connection error or deadlock error
# before error is raised. Set to -1 to specify an infinite retry count.
# Defaults to $::os_service_default
#
# [*database_connection*]
# (optional) Connection url to connect to nova database.
# Defaults to $::os_service_default
@ -34,14 +29,6 @@
# (optional) Connection url to connect to nova slave database (read-only).
# Defaults to $::os_service_default
#
# [*api_database_connection*]
# (optional) Connection url to connect to nova api database.
# Defaults to $::os_service_default
#
# [*api_slave_connection*]
# (optional) Connection url to connect to nova api slave database (read-only).
# Defaults to $::os_service_default
#
# [*database_connection_recycle_time*]
# Timeout when db connections should be reaped.
# (Optional) Defaults to $::os_service_default
@ -67,11 +54,49 @@
# (Optional) If set, use this value for pool_timeout with SQLAlchemy.
# Defaults to $::os_service_default
#
# [*database_db_max_retries*]
# (optional) Maximum retries in case of connection error or deadlock error
# before error is raised. Set to -1 to specify an infinite retry count.
# Defaults to $::os_service_default
#
# [*mysql_enable_ndb*]
# (Optional) If True, transparently enables support for handling MySQL
# Cluster (NDB).
# Defaults to $::os_service_default
#
# [*api_database_connection*]
# (optional) Connection url to connect to nova api database.
# Defaults to $::os_service_default
#
# [*api_slave_connection*]
# (optional) Connection url to connect to nova api slave database (read-only).
# Defaults to $::os_service_default
#
# [*api_database_connection_recycle_time*]
# Timeout when nova api db connections should be reaped.
# (Optional) Defaults to $::os_service_default
#
# [*api_database_max_pool_size*]
# Maximum number of SQL connections to keep open in a pool.
# (Optional) Defaults to $::os_service_default
#
# [*api_database_max_retries*]
# Maximum db connection retries during startup.
# Setting -1 implies an infinite retry count.
# (Optional) Defaults to $::os_service_default
#
# [*api_database_retry_interval*]
# Interval between retries of opening a sql connection.
# (Optional) Defaults to $::os_service_default
#
# [*api_database_max_overflow*]
# If set, use this value for max_overflow with sqlalchemy.
# (Optional) Defaults to $::os_service_default
#
# [*api_database_pool_timeout*]
# (Optional) If set, use this value for pool_timeout with SQLAlchemy.
# Defaults to $::os_service_default
#
# DEPRECATED PARAMETERS
#
# [*database_min_pool_size*]
@ -79,20 +104,26 @@
# (Optional) Defaults to undef
#
class nova::db (
$database_db_max_retries = $::os_service_default,
$database_connection = $::os_service_default,
$slave_connection = $::os_service_default,
$api_database_connection = $::os_service_default,
$api_slave_connection = $::os_service_default,
$database_connection_recycle_time = $::os_service_default,
$database_max_pool_size = $::os_service_default,
$database_max_retries = $::os_service_default,
$database_retry_interval = $::os_service_default,
$database_max_overflow = $::os_service_default,
$database_pool_timeout = $::os_service_default,
$mysql_enable_ndb = $::os_service_default,
$database_connection = $::os_service_default,
$slave_connection = $::os_service_default,
$database_connection_recycle_time = $::os_service_default,
$database_max_pool_size = $::os_service_default,
$database_max_retries = $::os_service_default,
$database_retry_interval = $::os_service_default,
$database_max_overflow = $::os_service_default,
$database_pool_timeout = $::os_service_default,
$database_db_max_retries = $::os_service_default,
$mysql_enable_ndb = $::os_service_default,
$api_database_connection = $::os_service_default,
$api_slave_connection = $::os_service_default,
$api_database_connection_recycle_time = $::os_service_default,
$api_database_max_pool_size = $::os_service_default,
$api_database_max_retries = $::os_service_default,
$api_database_retry_interval = $::os_service_default,
$api_database_max_overflow = $::os_service_default,
$api_database_pool_timeout = $::os_service_default,
# DEPRECATED PARAMETERS
$database_min_pool_size = undef,
$database_min_pool_size = undef,
) {
include nova::deps
@ -130,12 +161,18 @@ class nova::db (
if !is_service_default($api_database_connection_real) {
oslo::db { 'api_database':
config => 'nova_config',
config_group => 'api_database',
connection => $api_database_connection_real,
slave_connection => $api_slave_connection_real,
config => 'nova_config',
config_group => 'api_database',
connection => $api_database_connection_real,
slave_connection => $api_slave_connection_real,
connection_recycle_time => $api_database_connection_recycle_time,
max_pool_size => $api_database_max_pool_size,
max_retries => $api_database_max_retries,
retry_interval => $api_database_retry_interval,
max_overflow => $api_database_max_overflow,
pool_timeout => $api_database_pool_timeout,
# Package management should be disabled here to avoid conflict.
manage_backend_package => false
manage_backend_package => false
}
}

11
releasenotes/notes/add_api_database_parameters-bab34198427af74b.yaml

@ -0,0 +1,11 @@
---
features:
- |
Add the support to configure following parameters for api_database:
- ``nova::db::api_database_connection_recycle_time``
- ``nova::db::api_database_max_pool_size``
- ``nova::db::api_database_max_retries``
- ``nova::db::api_database_retry_interval``
- ``nova::db::api_database_max_overflow``
- ``nova::db::api_database_pool_timeout``

80
spec/classes/nova_db_spec.rb

@ -7,33 +7,21 @@ describe 'nova::db' do
shared_examples 'nova::db' do
context 'with default parameters' do
it { should_not contain_nova_config('database/db_max_retries') }
it { should_not contain_nova_config('database/connection') }
it { should_not contain_nova_config('database/slave_connection') }
it { should_not contain_nova_config('api_database/connection') }
it { should_not contain_nova_config('api_database/slave_connection') }
it { should_not contain_nova_config('database/connection_recycle_time') }
it { should_not contain_nova_config('database/max_pool_size') }
it { should_not contain_nova_config('database/max_retries') }
it { should_not contain_nova_config('database/retry_interval') }
it { should_not contain_nova_config('database/max_overflow') }
it { should_not contain_nova_config('database/pool_timeout') }
it { should_not contain_nova_config('database/mysql_enable_ndb') }
it { should_not contain_oslo__db('nova_config') }
it { should_not contain_oslo__db('api_database') }
end
context 'with overridden parameters' do
context 'with connection parameters' do
before :each do
params.merge!(
:database_connection => 'mysql+pymysql://user:pass@db/db1',
:slave_connection => 'mysql+pymysql://user:pass@slave/db1',
:api_database_connection => 'mysql+pymysql://user:pass@db/db2',
:api_slave_connection => 'mysql+pymysql://user:pass@slave/db2',
:database_connection => 'mysql+pymysql://user:pass@db/db1',
:api_database_connection => 'mysql+pymysql://user:pass@db/db2'
)
end
it { should contain_oslo__db('nova_config').with(
:connection => 'mysql+pymysql://user:pass@db/db1',
:slave_connection => 'mysql+pymysql://user:pass@slave/db1',
:slave_connection => '<SERVICE DEFAULT>',
:db_max_retries => '<SERVICE DEFAULT>',
:connection_recycle_time => '<SERVICE DEFAULT>',
:max_pool_size => '<SERVICE DEFAULT>',
@ -43,12 +31,68 @@ describe 'nova::db' do
:pool_timeout => '<SERVICE DEFAULT>',
:mysql_enable_ndb => '<SERVICE DEFAULT>',
)}
it { should contain_oslo__db('api_database').with(
:config => 'nova_config',
:config_group => 'api_database',
:connection => 'mysql+pymysql://user:pass@db/db2',
:slave_connection => '<SERVICE DEFAULT>',
:connection_recycle_time => '<SERVICE DEFAULT>',
:max_pool_size => '<SERVICE DEFAULT>',
:max_retries => '<SERVICE DEFAULT>',
:retry_interval => '<SERVICE DEFAULT>',
:max_overflow => '<SERVICE DEFAULT>',
:pool_timeout => '<SERVICE DEFAULT>',
)}
end
context 'with overridden parameters' do
before :each do
params.merge!(
:database_connection => 'mysql+pymysql://user:pass@db/db1',
:slave_connection => 'mysql+pymysql://user:pass@slave/db1',
:database_connection_recycle_time => '1800',
:database_max_pool_size => '30',
:database_max_retries => '20',
:database_retry_interval => '15',
:database_max_overflow => '5',
:database_pool_timeout => '20',
:database_db_max_retries => '10',
:mysql_enable_ndb => 'true',
:api_database_connection => 'mysql+pymysql://user:pass@db/db2',
:api_slave_connection => 'mysql+pymysql://user:pass@slave/db2',
:api_database_connection_recycle_time => '600',
:api_database_max_pool_size => '20',
:api_database_max_retries => '10',
:api_database_retry_interval => '5',
:api_database_max_overflow => '0',
:api_database_pool_timeout => '30',
)
end
it { should contain_oslo__db('nova_config').with(
:connection => 'mysql+pymysql://user:pass@db/db1',
:slave_connection => 'mysql+pymysql://user:pass@slave/db1',
:connection_recycle_time => '1800',
:max_pool_size => '30',
:max_retries => '20',
:retry_interval => '15',
:max_overflow => '5',
:pool_timeout => '20',
:db_max_retries => '10',
:mysql_enable_ndb => 'true',
)}
it { should contain_oslo__db('api_database').with(
:config => 'nova_config',
:config_group => 'api_database',
:connection => 'mysql+pymysql://user:pass@db/db2',
:slave_connection => 'mysql+pymysql://user:pass@slave/db2',
:connection_recycle_time => '600',
:max_pool_size => '20',
:max_retries => '10',
:retry_interval => '5',
:max_overflow => '0',
:pool_timeout => '30',
)}
end
end

Loading…
Cancel
Save