Add support to configure token caching in keystone
Add support to configure token caching in keystone[1] using memcached, so that we can improve performance about token validation. [1] https://docs.openstack.org/keystone/latest/admin/configuration.html#caching-layer Change-Id: I351eb64ff1df652b0a284d8cd3d835cec58a310f
This commit is contained in:
parent
36cbe74aad
commit
469d432195
@ -158,6 +158,14 @@
|
|||||||
# (Optional) Array of ipv4 or ipv6 addresses for memcache.
|
# (Optional) Array of ipv4 or ipv6 addresses for memcache.
|
||||||
# Defaults to hiera('memcached_node_ips')
|
# Defaults to hiera('memcached_node_ips')
|
||||||
#
|
#
|
||||||
|
# [*enable_token_caching*]
|
||||||
|
# (Optional) Enable token caching using memcached
|
||||||
|
# Defaults to false
|
||||||
|
#
|
||||||
|
# [*cache_backend*]
|
||||||
|
# (Optional) Backend implementation to store cache
|
||||||
|
# Defaults to 'oslo_cache.memcache_pool'
|
||||||
|
#
|
||||||
class tripleo::profile::base::keystone (
|
class tripleo::profile::base::keystone (
|
||||||
$admin_endpoint_network = hiera('keystone_admin_api_network', undef),
|
$admin_endpoint_network = hiera('keystone_admin_api_network', undef),
|
||||||
$bootstrap_node = hiera('keystone_short_bootstrap_node_name', undef),
|
$bootstrap_node = hiera('keystone_short_bootstrap_node_name', undef),
|
||||||
@ -190,7 +198,9 @@ class tripleo::profile::base::keystone (
|
|||||||
$keystone_enable_member = hiera('keystone_enable_member', false),
|
$keystone_enable_member = hiera('keystone_enable_member', false),
|
||||||
$keystone_federation_enabled = hiera('keystone_federation_enabled', false),
|
$keystone_federation_enabled = hiera('keystone_federation_enabled', false),
|
||||||
$keystone_openidc_enabled = hiera('keystone_openidc_enabled', false),
|
$keystone_openidc_enabled = hiera('keystone_openidc_enabled', false),
|
||||||
$memcached_ips = hiera('memcached_node_ips', [])
|
$memcached_ips = hiera('memcached_node_ips', []),
|
||||||
|
$enable_token_caching = false,
|
||||||
|
$cache_backend = 'oslo_cache.memcache_pool',
|
||||||
) {
|
) {
|
||||||
if $::hostname == downcase($bootstrap_node) {
|
if $::hostname == downcase($bootstrap_node) {
|
||||||
$sync_db = true
|
$sync_db = true
|
||||||
@ -222,6 +232,8 @@ class tripleo::profile::base::keystone (
|
|||||||
if $step >= 4 or ( $step >= 3 and $sync_db ) {
|
if $step >= 4 or ( $step >= 3 and $sync_db ) {
|
||||||
$oslomsg_rpc_use_ssl_real = sprintf('%s', bool2num(str2bool($oslomsg_rpc_use_ssl)))
|
$oslomsg_rpc_use_ssl_real = sprintf('%s', bool2num(str2bool($oslomsg_rpc_use_ssl)))
|
||||||
$oslomsg_notify_use_ssl_real = sprintf('%s', bool2num(str2bool($oslomsg_notify_use_ssl)))
|
$oslomsg_notify_use_ssl_real = sprintf('%s', bool2num(str2bool($oslomsg_notify_use_ssl)))
|
||||||
|
$memcached_servers = suffix(any2array(normalize_ip_for_uri($memcached_ips)), ':11211')
|
||||||
|
|
||||||
class { '::keystone':
|
class { '::keystone':
|
||||||
sync_db => $sync_db,
|
sync_db => $sync_db,
|
||||||
enable_bootstrap => $sync_db,
|
enable_bootstrap => $sync_db,
|
||||||
@ -243,7 +255,11 @@ class tripleo::profile::base::keystone (
|
|||||||
}),
|
}),
|
||||||
notification_topics => union($ceilometer_notification_topics,
|
notification_topics => union($ceilometer_notification_topics,
|
||||||
$barbican_notification_topics,
|
$barbican_notification_topics,
|
||||||
$extra_notification_topics)
|
$extra_notification_topics),
|
||||||
|
cache_enabled => $enable_token_caching,
|
||||||
|
cache_memcache_servers => $memcached_servers,
|
||||||
|
cache_backend => $cache_backend,
|
||||||
|
token_caching => $enable_token_caching
|
||||||
}
|
}
|
||||||
|
|
||||||
if 'amqp' in [$oslomsg_rpc_proto, $oslomsg_notify_proto]{
|
if 'amqp' in [$oslomsg_rpc_proto, $oslomsg_notify_proto]{
|
||||||
@ -278,8 +294,6 @@ class tripleo::profile::base::keystone (
|
|||||||
}
|
}
|
||||||
|
|
||||||
if $keystone_openidc_enabled {
|
if $keystone_openidc_enabled {
|
||||||
$memcached_servers = suffix(any2array(normalize_ip_for_uri($memcached_ips)), ':11211')
|
|
||||||
|
|
||||||
class { '::keystone::federation::openidc':
|
class { '::keystone::federation::openidc':
|
||||||
memcached_servers => $memcached_servers,
|
memcached_servers => $memcached_servers,
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,4 @@
|
|||||||
|
---
|
||||||
|
features:
|
||||||
|
- |
|
||||||
|
Adds support to configure keystone token caching using memcached
|
@ -30,6 +30,7 @@ describe 'tripleo::profile::base::keystone' do
|
|||||||
:oslomsg_notify_username => 'keystone2',
|
:oslomsg_notify_username => 'keystone2',
|
||||||
:oslomsg_notify_password => 'baa',
|
:oslomsg_notify_password => 'baa',
|
||||||
:oslomsg_notify_port => '5678',
|
:oslomsg_notify_port => '5678',
|
||||||
|
:memcached_ips => [ '192.168.0.3', '192.168.0.4', '192.168.0.5' ]
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -62,7 +63,11 @@ describe 'tripleo::profile::base::keystone' do
|
|||||||
it 'should trigger complete configuration' do
|
it 'should trigger complete configuration' do
|
||||||
is_expected.to contain_class('keystone').with(
|
is_expected.to contain_class('keystone').with(
|
||||||
:default_transport_url => 'rabbit://keystone1:foo@192.168.0.1:1234/?ssl=0',
|
:default_transport_url => 'rabbit://keystone1:foo@192.168.0.1:1234/?ssl=0',
|
||||||
:notification_transport_url => 'rabbit://keystone2:baa@192.168.0.2:5678/?ssl=0'
|
:notification_transport_url => 'rabbit://keystone2:baa@192.168.0.2:5678/?ssl=0',
|
||||||
|
:cache_enabled => false,
|
||||||
|
:cache_memcache_servers => [ '192.168.0.3:11211', '192.168.0.4:11211', '192.168.0.5:11211' ],
|
||||||
|
:cache_backend => 'oslo_cache.memcache_pool',
|
||||||
|
:token_caching => false
|
||||||
)
|
)
|
||||||
is_expected.to contain_class('keystone::config')
|
is_expected.to contain_class('keystone::config')
|
||||||
is_expected.to contain_class('keystone::logging')
|
is_expected.to contain_class('keystone::logging')
|
||||||
@ -108,7 +113,11 @@ describe 'tripleo::profile::base::keystone' do
|
|||||||
it 'should trigger keystone configuration' do
|
it 'should trigger keystone configuration' do
|
||||||
is_expected.to contain_class('keystone').with(
|
is_expected.to contain_class('keystone').with(
|
||||||
:default_transport_url => 'rabbit://keystone1:foo@192.168.0.1:1234/?ssl=0',
|
:default_transport_url => 'rabbit://keystone1:foo@192.168.0.1:1234/?ssl=0',
|
||||||
:notification_transport_url => 'rabbit://keystone2:baa@192.168.0.2:5678/?ssl=0'
|
:notification_transport_url => 'rabbit://keystone2:baa@192.168.0.2:5678/?ssl=0',
|
||||||
|
:cache_enabled => false,
|
||||||
|
:cache_memcache_servers => [ '192.168.0.3:11211', '192.168.0.4:11211', '192.168.0.5:11211' ],
|
||||||
|
:cache_backend => 'oslo_cache.memcache_pool',
|
||||||
|
:token_caching => false
|
||||||
)
|
)
|
||||||
is_expected.to contain_class('keystone::config')
|
is_expected.to contain_class('keystone::config')
|
||||||
is_expected.to contain_class('keystone::logging')
|
is_expected.to contain_class('keystone::logging')
|
||||||
@ -134,7 +143,11 @@ describe 'tripleo::profile::base::keystone' do
|
|||||||
it 'should trigger keystone configuration' do
|
it 'should trigger keystone configuration' do
|
||||||
is_expected.to contain_class('keystone').with(
|
is_expected.to contain_class('keystone').with(
|
||||||
:default_transport_url => 'rabbit://keystone1:foo@192.168.0.1:1234/?ssl=0',
|
:default_transport_url => 'rabbit://keystone1:foo@192.168.0.1:1234/?ssl=0',
|
||||||
:notification_transport_url => 'rabbit://keystone2:baa@192.168.0.2:5678/?ssl=0'
|
:notification_transport_url => 'rabbit://keystone2:baa@192.168.0.2:5678/?ssl=0',
|
||||||
|
:cache_enabled => false,
|
||||||
|
:cache_memcache_servers => [ '192.168.0.3:11211', '192.168.0.4:11211', '192.168.0.5:11211' ],
|
||||||
|
:cache_backend => 'oslo_cache.memcache_pool',
|
||||||
|
:token_caching => false
|
||||||
)
|
)
|
||||||
is_expected.to contain_class('keystone::config')
|
is_expected.to contain_class('keystone::config')
|
||||||
is_expected.to contain_class('keystone::logging')
|
is_expected.to contain_class('keystone::logging')
|
||||||
@ -148,6 +161,24 @@ describe 'tripleo::profile::base::keystone' do
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context 'with step 4 and token_caching eabled' do
|
||||||
|
before do
|
||||||
|
params.merge!(
|
||||||
|
{ :step => 4,
|
||||||
|
:bootstrap_node => 'other.example.com',
|
||||||
|
:enable_token_caching => true
|
||||||
|
}
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'should trigger token_caching configuration' do
|
||||||
|
is_expected.to contain_class('keystone').with(
|
||||||
|
:cache_enabled => true,
|
||||||
|
:token_caching => true
|
||||||
|
)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
context 'with step less than 4 and db_purge enabled' do
|
context 'with step less than 4 and db_purge enabled' do
|
||||||
before do
|
before do
|
||||||
params.merge!(
|
params.merge!(
|
||||||
|
Loading…
Reference in New Issue
Block a user