
- Require Chef >= 16.0 - Enable unified_mode - Update to latest upstream cookbooks for etcd, mariadb and memcached - Update copyright years Depends-On: https://review.opendev.org/c/openstack/openstack-chef/+/813950 Change-Id: Ib410ed28388725751a6295c58ce1f5e89c529b28 Signed-off-by: Lance Albertson <lance@osuosl.org>
126 lines
5.3 KiB
Ruby
126 lines
5.3 KiB
Ruby
#
|
|
# Cookbook:: openstack-common
|
|
# Attributes:: messaging
|
|
#
|
|
# Copyright:: 2012-2021, AT&T Services, Inc.
|
|
# Copyright:: 2013-2021, SUSE Linux GmbH
|
|
# Copyright:: 2013-2021, 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 **************************************
|
|
%w(endpoints bind_service).each do |type|
|
|
default['openstack'][type]['mq']['host'] = '127.0.0.1'
|
|
default['openstack'][type]['mq']['port'] = '5672'
|
|
end
|
|
default['openstack']['bind_service']['mq']['interface'] = nil
|
|
|
|
###################################################################
|
|
# Services to assign mq attributes for
|
|
###################################################################
|
|
services =
|
|
%w(
|
|
aodh
|
|
bare_metal
|
|
baremetal
|
|
block-storage
|
|
block_storage
|
|
compute
|
|
database
|
|
dns
|
|
identity
|
|
image
|
|
load_balancer
|
|
network
|
|
orchestration
|
|
placement
|
|
telemetry
|
|
)
|
|
|
|
###################################################################
|
|
# Generic default attributes
|
|
###################################################################
|
|
default['openstack']['mq']['server_role'] = 'os-ops-messaging'
|
|
default['openstack']['mq']['service_type'] = 'rabbit'
|
|
default['openstack']['mq']['user'] = 'openstack'
|
|
default['openstack']['mq']['vhost'] = '/'
|
|
|
|
# defined in oslo/messaging/_drivers/amqp.py
|
|
default['openstack']['mq']['durable_queues'] = false
|
|
default['openstack']['mq']['auto_delete'] = false
|
|
|
|
###################################################################
|
|
# Default rabbit values (for attribute assignment below)
|
|
###################################################################
|
|
# 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
|
|
# SSL key file (valid only if SSL enabled)
|
|
default['openstack']['mq']['rabbitmq']['kombu_ssl_keyfile'] = nil
|
|
# SSL cert file (valid only if SSL enabled)
|
|
default['openstack']['mq']['rabbitmq']['kombu_ssl_certfile'] = nil
|
|
# SSL certification authority file (valid only if SSL enabled)
|
|
default['openstack']['mq']['rabbitmq']['kombu_ssl_ca_certs'] = nil
|
|
# How long to wait before reconnecting in response to an AMQP consumer cancel notification
|
|
default['openstack']['mq']['rabbitmq']['kombu_reconnect_delay'] = 1.0
|
|
# How long to wait before considering a reconnect attempt to have failed.
|
|
# This value should not be longer than rpc_response_timeout
|
|
default['openstack']['mq']['rabbitmq']['kombu_reconnect_timeout'] = 60
|
|
# global switch for handling rabbit ha
|
|
default['openstack']['mq']['rabbitmq']['ha'] = false
|
|
# global switch for number of seconds after which the Rabbit broker is considered down if heartbeat's keep-alive fails (0 disable the heartbeat)
|
|
default['openstack']['mq']['rabbitmq']['heartbeat_timeout_threshold'] = 0
|
|
# global switch for how often times during the heartbeat_timeout_threshold we check the heartbeat
|
|
default['openstack']['mq']['rabbitmq']['heartbeat_rate'] = 2
|
|
|
|
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'],
|
|
heartbeat_timeout_threshold: node['openstack']['mq']['rabbitmq']['heartbeat_timeout_threshold'],
|
|
heartbeat_rate: node['openstack']['mq']['rabbitmq']['heartbeat_rate'],
|
|
use_ssl: node['openstack']['mq']['rabbitmq']['use_ssl'],
|
|
kombu_ssl_version: node['openstack']['mq']['rabbitmq']['kombu_ssl_version'],
|
|
kombu_ssl_keyfile: node['openstack']['mq']['rabbitmq']['kombu_ssl_keyfile'],
|
|
kombu_ssl_certfile: node['openstack']['mq']['rabbitmq']['kombu_ssl_certfile'],
|
|
kombu_ssl_ca_certs: node['openstack']['mq']['rabbitmq']['kombu_ssl_ca_certs'],
|
|
kombu_reconnect_delay: node['openstack']['mq']['rabbitmq']['kombu_reconnect_delay'],
|
|
kombu_reconnect_timeout: node['openstack']['mq']['rabbitmq']['kombu_reconnect_timeout'],
|
|
}
|
|
|
|
###################################################################
|
|
# 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]['durable_queues'] =
|
|
node['openstack']['mq']['durable_queues']
|
|
default['openstack']['mq'][svc]['auto_delete'] =
|
|
node['openstack']['mq']['auto_delete']
|
|
|
|
rabbit_defaults.each do |key, val|
|
|
default['openstack']['mq'][svc]['rabbit'][key.to_s] = val
|
|
end
|
|
end
|