Configure compute params in config

Add a way to pass instance_discovery_method param to
override in the ceilo compute agent config.

Change-Id: Id7bd49510c0be76ed3f940c91108659beb440afb
This commit is contained in:
Pradeep Kilambi 2017-01-16 13:15:03 -05:00
parent 306c6d660d
commit 9cf46cbf92
5 changed files with 76 additions and 10 deletions

View File

@ -17,16 +17,29 @@
# (Optional) ensure state for package. # (Optional) ensure state for package.
# Defaults to 'present'. # Defaults to 'present'.
# #
# [*instance_discovery_method*]
# (Optional) method to discovery instances running on compute node
# Defaults to $::os_service_default
# * naive: poll nova to get all instances
# * workload_partitioning: poll nova to get instances of the compute
# * libvirt_metadata: get instances from libvirt metadata
# but without instance metadata (recommended for Gnocchi backend).
#
class ceilometer::agent::compute ( class ceilometer::agent::compute (
$manage_service = true, $manage_service = true,
$enabled = true, $enabled = true,
$package_ensure = 'present', $package_ensure = 'present',
$instance_discovery_method = $::os_service_default,
) inherits ceilometer { ) inherits ceilometer {
warning('This class is deprecated. Please use ceilometer::agent::polling with compute namespace instead.') warning('This class is deprecated. Please use ceilometer::agent::polling with compute namespace instead.')
include ::ceilometer::params include ::ceilometer::params
ceilometer_config {
'compute/instance_discovery_method': value => $instance_discovery_method,
}
Ceilometer_config<||> ~> Service['ceilometer-agent-compute'] Ceilometer_config<||> ~> Service['ceilometer-agent-compute']
Package['ceilometer-agent-compute'] -> Service['ceilometer-agent-compute'] Package['ceilometer-agent-compute'] -> Service['ceilometer-agent-compute']

View File

@ -32,6 +32,14 @@
# (Optional) The url to use for distributed group membership coordination. # (Optional) The url to use for distributed group membership coordination.
# Defaults to undef. # Defaults to undef.
# #
# [*instance_discovery_method*]
# (Optional) method to discovery instances running on compute node
# Defaults to $::os_service_default
# * naive: poll nova to get all instances
# * workload_partitioning: poll nova to get instances of the compute
# * libvirt_metadata: get instances from libvirt metadata
# but without instance metadata (recommended for Gnocchi backend).
#
class ceilometer::agent::polling ( class ceilometer::agent::polling (
$manage_service = true, $manage_service = true,
$enabled = true, $enabled = true,
@ -40,6 +48,7 @@ class ceilometer::agent::polling (
$compute_namespace = true, $compute_namespace = true,
$ipmi_namespace = true, $ipmi_namespace = true,
$coordination_url = undef, $coordination_url = undef,
$instance_discovery_method = $::os_service_default,
) inherits ceilometer { ) inherits ceilometer {
include ::ceilometer::deps include ::ceilometer::deps
@ -65,6 +74,10 @@ class ceilometer::agent::polling (
Package <| title == 'ceilometer-common' |> -> User['ceilometer'] Package <| title == 'ceilometer-common' |> -> User['ceilometer']
Package <| title == 'nova-common' |> -> Package['ceilometer-common'] Package <| title == 'nova-common' |> -> Package['ceilometer-common']
ceilometer_config {
'compute/instance_discovery_method': value => $instance_discovery_method,
}
} }
if $ipmi_namespace { if $ipmi_namespace {

View File

@ -0,0 +1,9 @@
---
features:
- Add instance_discovery_method to ceilometer agent compute and polling
classes so this option is configurable.
upgrade:
- When upgrading, ensure that you dont have both the agent compute as well
as the polling classes initialized as that would trigger a duplicate
declaration. Ceilometer::agent::compute is deprecated and will be removed
in pike release.

View File

@ -28,6 +28,10 @@ describe 'ceilometer::agent::compute' do
) )
end end
it 'configures agent compute default instance discovery' do
is_expected.to contain_ceilometer_config('compute/instance_discovery_method').with_value('<SERVICE DEFAULT>')
end
it 'adds ceilometer user to nova group and, if required, to libvirt group' do it 'adds ceilometer user to nova group and, if required, to libvirt group' do
if platform_params[:libvirt_group] if platform_params[:libvirt_group]
is_expected.to contain_user('ceilometer').with_groups(['nova', "#{platform_params[:libvirt_group]}"]) is_expected.to contain_user('ceilometer').with_groups(['nova', "#{platform_params[:libvirt_group]}"])
@ -68,6 +72,18 @@ describe 'ceilometer::agent::compute' do
end end
end end
context 'when setting instance_discovery_method' do
before do
params.merge!({ :instance_discovery_method => 'naive' })
end
it 'configures agent compute instance discovery' do
is_expected.to contain_ceilometer_config('compute/instance_discovery_method').with_value('naive')
end
end
context 'with disabled service managing' do context 'with disabled service managing' do
before do before do
params.merge!({ params.merge!({

View File

@ -38,6 +38,10 @@ describe 'ceilometer::agent::polling' do
:before => /Package\[ceilometer-common\]/ :before => /Package\[ceilometer-common\]/
) )
end end
it 'configures agent compute' do
is_expected.to contain_ceilometer_config('compute/instance_discovery_method').with_value('<SERVICE DEFAULT>')
end
end end
it 'installs ceilometer-polling package' do it 'installs ceilometer-polling package' do
@ -71,6 +75,17 @@ describe 'ceilometer::agent::polling' do
end end
end end
context 'when setting instance_discovery_method' do
before do
params.merge!({ :instance_discovery_method => 'naive' })
end
it 'configures agent compute instance discovery' do
is_expected.to contain_ceilometer_config('compute/instance_discovery_method').with_value('naive')
end
end
context 'with central and ipmi polling namespaces disabled' do context 'with central and ipmi polling namespaces disabled' do
before do before do
params.merge!({ params.merge!({