81687e2ead
In Puppet 3 there was a need to use absolute names to prevent issues. Since Puppet 4 everything is absolute by default which makes this not needed. We need to change this everywhere so that we can revert the pin in [1] that now prevents us from using the latest version of the puppet-lint check puppet-lint-absolute_classname_check that properly checks that we dont use absolute names. [1] https://review.opendev.org/#/c/697742/ Change-Id: I78b74fbeb08be7234189e4d266412fb7fb7a73c0
107 lines
3.9 KiB
Puppet
107 lines
3.9 KiB
Puppet
# Configure the Ceilometer service
|
|
#
|
|
# [*compute_namespace*]
|
|
# (optional) Enable polling for the compute namespace
|
|
# Default to true.
|
|
#
|
|
# [*integration_enable*]
|
|
# (optional) Boolean to run integration tests.
|
|
# Defaults to true.
|
|
#
|
|
class openstack_integration::ceilometer (
|
|
$compute_namespace = true,
|
|
$integration_enable = true,
|
|
){
|
|
|
|
include openstack_integration::config
|
|
include openstack_integration::params
|
|
|
|
openstack_integration::mq_user { 'ceilometer':
|
|
password => 'an_even_bigger_secret',
|
|
before => Anchor['ceilometer::service::begin'],
|
|
}
|
|
|
|
if $::openstack_integration::config::ssl {
|
|
openstack_integration::ssl_key { 'ceilometer':
|
|
notify => Service['httpd'],
|
|
require => Package['ceilometer-common'],
|
|
}
|
|
Exec['update-ca-certificates'] ~> Service['httpd']
|
|
}
|
|
|
|
class { 'ceilometer::logging':
|
|
debug => true,
|
|
}
|
|
class { 'ceilometer':
|
|
telemetry_secret => 'secrete',
|
|
default_transport_url => os_transport_url({
|
|
'transport' => $::openstack_integration::config::messaging_default_proto,
|
|
'host' => $::openstack_integration::config::host,
|
|
'port' => $::openstack_integration::config::messaging_default_port,
|
|
'username' => 'ceilometer',
|
|
'password' => 'an_even_bigger_secret',
|
|
}),
|
|
notification_transport_url => os_transport_url({
|
|
'transport' => $::openstack_integration::config::messaging_notify_proto,
|
|
'host' => $::openstack_integration::config::host,
|
|
'port' => $::openstack_integration::config::messaging_notify_port,
|
|
'username' => 'ceilometer',
|
|
'password' => 'an_even_bigger_secret',
|
|
}),
|
|
rabbit_use_ssl => $::openstack_integration::config::ssl,
|
|
amqp_sasl_mechanisms => 'PLAIN',
|
|
memcache_servers => $::openstack_integration::config::memcached_servers,
|
|
}
|
|
class { 'ceilometer::keystone::auth':
|
|
public_url => "${::openstack_integration::config::base_url}:8777",
|
|
internal_url => "${::openstack_integration::config::base_url}:8777",
|
|
admin_url => "${::openstack_integration::config::base_url}:8777",
|
|
password => 'a_big_secret',
|
|
configure_endpoint => false,
|
|
}
|
|
|
|
if $integration_enable {
|
|
# Ensure Gnocchi and creads are ready before running ceilometer-upgrade
|
|
# We use Gnocchi/Panko instead of local database, db::sync is required to populate
|
|
# gnocchi resource types.
|
|
include ceilometer::db::sync
|
|
Service['httpd'] -> Exec['ceilometer-upgrade']
|
|
Class['ceilometer::agent::auth'] -> Exec['ceilometer-upgrade']
|
|
Class['ceilometer::keystone::auth'] -> Exec['ceilometer-upgrade']
|
|
Class['gnocchi::keystone::auth'] -> Exec['ceilometer-upgrade']
|
|
|
|
# The default pipeline doesn't have Panko
|
|
$sample_pipeline_publishers = ['gnocchi://']
|
|
$event_pipeline_publishers = ['gnocchi://', 'panko://']
|
|
|
|
class { 'ceilometer::agent::notification':
|
|
notification_workers => '2',
|
|
manage_pipeline => true,
|
|
pipeline_publishers => $sample_pipeline_publishers,
|
|
manage_event_pipeline => true,
|
|
event_pipeline_publishers => $event_pipeline_publishers,
|
|
}
|
|
class { 'ceilometer::agent::polling':
|
|
manage_polling => true,
|
|
compute_namespace => $compute_namespace,
|
|
# NOTE(sileht): Use 1 minute instead 10 otherwise the telemetry tempest
|
|
# tests are too long to pass in less than 1 hour.
|
|
polling_interval => 60,
|
|
}
|
|
} else {
|
|
# NOTE(tobasco): When running the beaker tests we need to exclude the
|
|
# gnocchi resource types since the acceptance test does not setup gnocchi itself.
|
|
class { 'ceilometer::db::sync':
|
|
extra_params => '--skip-gnocchi-resource-types',
|
|
}
|
|
class { 'ceilometer::agent::notification': }
|
|
}
|
|
|
|
class { 'ceilometer::expirer': }
|
|
class { 'ceilometer::agent::auth':
|
|
auth_password => 'a_big_secret',
|
|
auth_url => $::openstack_integration::config::keystone_auth_uri,
|
|
}
|
|
|
|
}
|