fuel-library/deployment/puppet/osnailyfacter/modular/openstack-cinder/openstack-cinder.pp
Aleksandr Didenko e8ff3f01b4 Possibility to detach cinder from controllers
Adds the possibility to use external (non-controllers) keystone,
db, rabbitmq, etc for cinder services.

Partial blueprint: detach-components-from-controllers

Change-Id: I46582e9199bc9ed389f1b441306b8b109325c69a
2015-06-24 09:27:27 +00:00

106 lines
4.2 KiB
Puppet

notice('MODULAR: openstack-cinder.pp')
$cinder_hash = hiera_hash('cinder', {})
$management_vip = hiera('management_vip')
$queue_provider = hiera('queue_provider', 'rabbitmq')
$internal_address = hiera('internal_address')
$cinder_volume_group = hiera('cinder_volume_group', 'cinder')
$controller_nodes = hiera('controller_nodes')
$nodes_hash = hiera('nodes', {})
$storage_hash = hiera('storage', {})
$storage_address = hiera('storage_address')
$ceilometer_hash = hiera('ceilometer',{})
$rabbit_hash = hiera_hash('rabbit_hash', {})
$service_endpoint = hiera('service_endpoint', $management_vip)
$cinder_db_password = $cinder_hash[db_password]
$cinder_user_password = $cinder_hash[user_password]
$keystone_user = pick($cinder_hash['user'], 'cinder')
$keystone_tenant = pick($cinder_hash['tenant'], 'services')
$db_host = pick($cinder_hash['db_host'], $management_vip)
$cinder_db_user = pick($cinder_hash['db_user'], 'cinder')
$cinder_db_name = pick($cinder_hash['db_name'], 'cinder')
$roles = node_roles($nodes_hash, hiera('uid'))
if hiera('amqp_nodes', false) {
$amqp_nodes = hiera('amqp_nodes')
}
elsif $internal_address in $controller_nodes {
# prefer local MQ broker if it exists on this node
$amqp_nodes = concat(['127.0.0.1'], fqdn_rotate(delete($controller_nodes, $internal_address)))
} else {
$amqp_nodes = fqdn_rotate($controller_nodes)
}
$amqp_port = hiera('amqp_port', '5673')
$amqp_hosts = inline_template("<%= @amqp_nodes.map {|x| x + ':' + @amqp_port}.join ',' %>")
# Determine who should get the volume service
if (member($roles, 'cinder') and $storage_hash['volumes_lvm']) {
$manage_volumes = 'iscsi'
} elsif ($storage_hash['volumes_ceph']) {
$manage_volumes = 'ceph'
} elsif member($roles, 'cinder-vmware') {
$manage_volumes = 'vmdk'
} else {
$manage_volumes = false
}
# SQLAlchemy backend configuration
$max_pool_size = min($::processorcount * 5 + 0, 30 + 0)
$max_overflow = min($::processorcount * 5 + 0, 60 + 0)
$max_retries = '-1'
$idle_timeout = '3600'
$openstack_version = {
'keystone' => 'installed',
'glance' => 'installed',
'horizon' => 'installed',
'nova' => 'installed',
'novncproxy' => 'installed',
'cinder' => 'installed',
}
######### Cinder Controller Services ########
class {'openstack::cinder':
sql_connection => "mysql://${cinder_db_user}:${cinder_db_password}@${db_host}/${cinder_db_name}?charset=utf8&read_timeout=60",
queue_provider => $queue_provider,
amqp_hosts => $amqp_hosts,
amqp_user => $rabbit_hash['user'],
amqp_password => $rabbit_hash['password'],
rabbit_ha_queues => true,
volume_group => $cinder_volume_group,
physical_volume => undef,
manage_volumes => $manage_volumes,
enabled => true,
glance_api_servers => "${service_endpoint}:9292",
auth_host => $service_endpoint,
bind_host => $internal_address,
iscsi_bind_host => $storage_address,
keystone_user => $keystone_user,
keystone_tenant => $keystone_tenant,
cinder_user_password => $cinder_user_password,
use_syslog => hiera('use_syslog', true),
verbose => hiera('verbose', true),
debug => hiera('debug', true),
syslog_log_facility => hiera('syslog_log_facility_cinder', 'LOG_LOCAL3'),
cinder_rate_limits => hiera('cinder_rate_limits'),
max_retries => $max_retries,
max_pool_size => $max_pool_size,
max_overflow => $max_overflow,
idle_timeout => $idle_timeout,
ceilometer => $ceilometer_hash[enabled],
} # end class
####### Disable upstart startup on install #######
if($::operatingsystem == 'Ubuntu') {
tweaks::ubuntu_service_override { 'cinder-api':
package_name => 'cinder-api',
}
tweaks::ubuntu_service_override { 'cinder-backup':
package_name => 'cinder-backup',
}
tweaks::ubuntu_service_override { 'cinder-scheduler':
package_name => 'cinder-scheduler',
}
}