22c46294d6
Oslo.message using rabbit_max_retries and rabbit_retry_interval to define reconnect rabbitmq server times and interval when can not connect to rabbitmq server. Change-Id: I6bba768f4cf0c61b92fbc5d682b60f094afb7180 Partial-bug: #1439968
162 lines
6.8 KiB
Ruby
162 lines
6.8 KiB
Ruby
# encoding: UTF-8
|
|
#
|
|
# Cookbook Name:: openstack-common
|
|
# Attributes:: messaging
|
|
#
|
|
# Copyright 2012-2013, AT&T Services, Inc.
|
|
# Copyright 2013-2014, SUSE Linux GmbH
|
|
# Copyright 2013-2014, Rackspace US, Inc.
|
|
#
|
|
# 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.
|
|
#
|
|
# The rabbitmq user's password is stored in an encrypted databag and accessed
|
|
# with openstack-common cookbook library's user_password routine. You are
|
|
# expected to create the user, pass, vhost in a wrapper rabbitmq cookbook.
|
|
#
|
|
|
|
# ******************** RabbitMQ Endpoint **************************************
|
|
default['openstack']['endpoints']['mq']['host'] = '127.0.0.1'
|
|
default['openstack']['endpoints']['mq']['scheme'] = nil
|
|
default['openstack']['endpoints']['mq']['port'] = '5672'
|
|
default['openstack']['endpoints']['mq']['path'] = nil
|
|
default['openstack']['endpoints']['mq']['bind_interface'] = nil
|
|
|
|
###################################################################
|
|
# Services to assign mq attributes for
|
|
###################################################################
|
|
services = %w{bare-metal block-storage compute database image
|
|
identity telemetry network orchestration}
|
|
|
|
###################################################################
|
|
# Generic default attributes
|
|
###################################################################
|
|
default['openstack']['mq']['server_role'] = 'os-ops-messaging'
|
|
default['openstack']['mq']['service_type'] = 'rabbitmq'
|
|
default['openstack']['mq']['user'] = 'guest'
|
|
default['openstack']['mq']['vhost'] = '/'
|
|
|
|
# defined in oslo/messaging/_drivers/amqp.py
|
|
default['openstack']['mq']['durable_queues'] = false
|
|
default['openstack']['mq']['auto_delete'] = false
|
|
|
|
###################################################################
|
|
# Default qpid and rabbit values (for attribute assignment below)
|
|
###################################################################
|
|
default['openstack']['mq']['qpid']['protocol'] = 'tcp'
|
|
# global switch for handling rabbit ssl
|
|
default['openstack']['mq']['rabbitmq']['use_ssl'] = false
|
|
# SSL version to use (valid only if SSL enabled)
|
|
default['openstack']['mq']['rabbitmq']['kombu_ssl_version'] = nil
|
|
# global switch for handling rabbit ha
|
|
default['openstack']['mq']['rabbitmq']['ha'] = false
|
|
# defined in oslo/messaging/_drivers/impl_qpid.py
|
|
default['openstack']['mq']['qpid']['topology_version'] = 1
|
|
qpid_defaults = {
|
|
username: node['openstack']['mq']['user'],
|
|
sasl_mechanisms: '',
|
|
reconnect: true,
|
|
reconnect_timeout: 0,
|
|
reconnect_limit: 0,
|
|
reconnect_interval_min: 0,
|
|
reconnect_interval_max: 0,
|
|
reconnect_interval: 0,
|
|
heartbeat: 60,
|
|
protocol: node['openstack']['mq']['qpid']['protocol'],
|
|
tcp_nodelay: true,
|
|
host: node['openstack']['endpoints']['mq']['host'],
|
|
port: node['openstack']['endpoints']['mq']['port'],
|
|
qpid_hosts: ["#{node['openstack']['endpoints']['mq']['host']}:#{node['openstack']['endpoints']['mq']['port']}"],
|
|
topology_version: node['openstack']['mq']['qpid']['topology_version']
|
|
}
|
|
|
|
rabbit_defaults = {
|
|
rabbit_max_retries: 0,
|
|
rabbit_retry_interval: 1,
|
|
userid: node['openstack']['mq']['user'],
|
|
vhost: node['openstack']['mq']['vhost'],
|
|
port: node['openstack']['endpoints']['mq']['port'],
|
|
host: node['openstack']['endpoints']['mq']['host'],
|
|
ha: node['openstack']['mq']['rabbitmq']['ha'],
|
|
use_ssl: node['openstack']['mq']['rabbitmq']['use_ssl'],
|
|
kombu_ssl_version: node['openstack']['mq']['rabbitmq']['kombu_ssl_version']
|
|
}
|
|
|
|
###################################################################
|
|
# Assign default mq attributes for every service
|
|
###################################################################
|
|
services.each do |svc|
|
|
default['openstack']['mq'][svc]['service_type'] = node['openstack']['mq']['service_type']
|
|
default['openstack']['mq'][svc]['notification_topic'] = 'notifications'
|
|
|
|
default['openstack']['mq'][svc]['durable_queues'] =
|
|
node['openstack']['mq']['durable_queues']
|
|
default['openstack']['mq'][svc]['auto_delete'] =
|
|
node['openstack']['mq']['auto_delete']
|
|
|
|
case node['openstack']['mq'][svc]['service_type']
|
|
when 'qpid'
|
|
qpid_defaults.each do |key, val|
|
|
default['openstack']['mq'][svc]['qpid'][key.to_s] = val
|
|
end
|
|
when 'rabbitmq'
|
|
rabbit_defaults.each do |key, val|
|
|
default['openstack']['mq'][svc]['rabbit'][key.to_s] = val
|
|
end
|
|
end
|
|
end
|
|
|
|
###################################################################
|
|
# Overrides and additional attributes for individual services
|
|
###################################################################
|
|
# bare-metal
|
|
default['openstack']['mq']['bare-metal']['qpid']['notification_topic'] =
|
|
node['openstack']['mq']['bare-metal']['notification_topic']
|
|
default['openstack']['mq']['bare-metal']['rabbit']['notification_topic'] =
|
|
node['openstack']['mq']['bare-metal']['notification_topic']
|
|
default['openstack']['mq']['bare-metal']['control_exchange'] = 'ironic'
|
|
|
|
# block-storage
|
|
default['openstack']['mq']['block-storage']['qpid']['notification_topic'] =
|
|
node['openstack']['mq']['block-storage']['notification_topic']
|
|
default['openstack']['mq']['block-storage']['rabbit']['notification_topic'] =
|
|
node['openstack']['mq']['block-storage']['notification_topic']
|
|
default['openstack']['mq']['block-storage']['control_exchange'] = 'cinder'
|
|
|
|
# image
|
|
default['openstack']['mq']['image']['notifier_strategy'] = 'noop'
|
|
default['openstack']['mq']['image']['notification_topic'] = 'glance_notifications'
|
|
default['openstack']['mq']['image']['qpid']['notification_topic'] =
|
|
node['openstack']['mq']['image']['notification_topic']
|
|
default['openstack']['mq']['image']['rabbit']['notification_topic'] =
|
|
node['openstack']['mq']['image']['notification_topic']
|
|
default['openstack']['mq']['image']['control_exchange'] = 'glance'
|
|
|
|
# identity
|
|
# AMQP topics used for openstack notifications, can be comma-separated values
|
|
default['openstack']['mq']['identity']['notification_topics'] = 'notifications'
|
|
default['openstack']['mq']['identity']['control_exchange'] = 'identity'
|
|
|
|
# network
|
|
# AMQP topics used for openstack notifications, can be comma-separated values
|
|
default['openstack']['mq']['network']['notification_topics'] = 'notifications'
|
|
default['openstack']['mq']['network']['control_exchange'] = 'neutron'
|
|
|
|
# compute
|
|
default['openstack']['mq']['compute']['control_exchange'] = 'nova'
|
|
|
|
# orchestration
|
|
default['openstack']['mq']['orchestration']['control_exchange'] = 'heat'
|
|
|
|
# telemetry
|
|
default['openstack']['mq']['telemetry']['control_exchange'] = 'ceilometer'
|