# # Copyright (C) 2014 eNovance SAS # # Licensed under the Apache License, Version 2.0 (the "License"); you may # not use this file except in compliance with the License. You may obtain # a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the # License for the specific language governing permissions and limitations # under the License. # # == Class: cloud::telemetry::api # # Telemetry API nodes # # === Parameters: # # [*ks_keystone_internal_host*] # (optional) Internal Hostname or IP to connect to Keystone API # Defaults to '127.0.0.1' # # [*ks_keystone_internal_proto*] # (optional) Protocol for public endpoint. Could be 'http' or 'https'. # Defaults to 'http' # # [*ks_ceilometer_password*] # (optional) Password used by Ceilometer to connect to Keystone API # Defaults to 'ceilometerpassword' # # [*ks_ceilometer_internal_port*] # (optional) TCP port to connect to Ceilometer API from public network # Defaults to '8777' # # [*api_eth*] # (optional) Which interface we bind the Ceilometer API server. # Defaults to '127.0.0.1' # # [*firewall_settings*] # (optional) Allow to add custom parameters to firewall rules # Should be an hash. # Default to {} # class cloud::telemetry::api( $ks_keystone_internal_host = '127.0.0.1', $ks_keystone_internal_proto = 'http', $ks_ceilometer_internal_port = '8777', $ks_ceilometer_password = 'ceilometerpassword', $api_eth = '127.0.0.1', $firewall_settings = {}, ){ include 'cloud::telemetry' class { 'ceilometer::api': keystone_password => $ks_ceilometer_password, keystone_host => $ks_keystone_internal_host, keystone_protocol => $ks_keystone_internal_proto, host => $api_eth } # Configure TTL for samples # Purge datas older than one month # Run the script once a day but with a random time to avoid # issues with MongoDB access class { 'ceilometer::expirer': time_to_live => '2592000', minute => '0', hour => '0', } Cron <<| title == 'ceilometer-expirer' |>> { command => "sleep $((\$RANDOM % 86400)) && ${::ceilometer::params::expirer_command}" } if $::cloud::manage_firewall { cloud::firewall::rule{ '100 allow ceilometer-api access': port => $ks_ceilometer_internal_port, extras => $firewall_settings, } } @@haproxy::balancermember{"${::fqdn}-ceilometer_api": listening_service => 'ceilometer_api_cluster', server_names => $::hostname, ipaddresses => $api_eth, ports => $ks_ceilometer_internal_port, options => 'check inter 2000 rise 2 fall 5' } }