Merge "Make sure we bind the rabbit inter-cluster to a specific interface"
This commit is contained in:
commit
d89ba57f59
31
lib/puppet/parser/functions/ip_to_erl_format.rb
Normal file
31
lib/puppet/parser/functions/ip_to_erl_format.rb
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
require 'ipaddr'
|
||||||
|
|
||||||
|
# Custom function to convert an IP4/6 address from a string to the
|
||||||
|
# erlang inet kernel format.
|
||||||
|
# For example from "172.17.0.16" to {172,17,0,16}
|
||||||
|
# See http://erlang.org/doc/man/kernel_app.html and http://erlang.org/doc/man/inet.html
|
||||||
|
# for more information.
|
||||||
|
module Puppet::Parser::Functions
|
||||||
|
newfunction(:ip_to_erl_format, :type => :rvalue, :doc => "Convert an IP address to the erlang inet format.") do |arg|
|
||||||
|
if arg[0].class != String
|
||||||
|
raise Puppet::ParseError, "Syntax error: #{arg[0]} must be a String"
|
||||||
|
end
|
||||||
|
ip = IPAddr.new arg[0]
|
||||||
|
output = '{'
|
||||||
|
if ip.ipv6?
|
||||||
|
split_char = ':'
|
||||||
|
base = 16
|
||||||
|
else
|
||||||
|
split_char = '.'
|
||||||
|
base = 10
|
||||||
|
end
|
||||||
|
# to_string() prints the canonicalized form
|
||||||
|
ip.to_string().split(split_char).each {
|
||||||
|
|x| output += x.to_i(base).to_s + ','
|
||||||
|
}
|
||||||
|
# Remove the last spurious comma
|
||||||
|
output = output.chomp(',')
|
||||||
|
output += '}'
|
||||||
|
return output
|
||||||
|
end
|
||||||
|
end
|
@ -34,6 +34,11 @@
|
|||||||
# (Optional) RabbitMQ environment.
|
# (Optional) RabbitMQ environment.
|
||||||
# Defaults to hiera('rabbitmq_environment').
|
# Defaults to hiera('rabbitmq_environment').
|
||||||
#
|
#
|
||||||
|
# [*inet_dist_interface*]
|
||||||
|
# (Optional) Address to bind the inter-cluster interface
|
||||||
|
# to. It is the inet_dist_use_interface option in the kernel variables
|
||||||
|
# Defaults to hiera('rabbitmq::interface', undef).
|
||||||
|
#
|
||||||
# [*nodes*]
|
# [*nodes*]
|
||||||
# (Optional) Array of host(s) for RabbitMQ nodes.
|
# (Optional) Array of host(s) for RabbitMQ nodes.
|
||||||
# Defaults to hiera('rabbitmq_node_names', []).
|
# Defaults to hiera('rabbitmq_node_names', []).
|
||||||
@ -44,12 +49,13 @@
|
|||||||
# Defaults to hiera('step')
|
# Defaults to hiera('step')
|
||||||
#
|
#
|
||||||
class tripleo::profile::base::rabbitmq (
|
class tripleo::profile::base::rabbitmq (
|
||||||
$config_variables = hiera('rabbitmq_config_variables'),
|
$config_variables = hiera('rabbitmq_config_variables'),
|
||||||
$environment = hiera('rabbitmq_environment'),
|
$environment = hiera('rabbitmq_environment'),
|
||||||
$ipv6 = str2bool(hiera('rabbit_ipv6', false)),
|
$ipv6 = str2bool(hiera('rabbit_ipv6', false)),
|
||||||
$kernel_variables = hiera('rabbitmq_kernel_variables'),
|
$kernel_variables = hiera('rabbitmq_kernel_variables'),
|
||||||
$nodes = hiera('rabbitmq_node_names', []),
|
$inet_dist_interface = hiera('rabbitmq::interface', undef),
|
||||||
$step = hiera('step'),
|
$nodes = hiera('rabbitmq_node_names', []),
|
||||||
|
$step = hiera('step'),
|
||||||
) {
|
) {
|
||||||
# IPv6 environment, necessary for RabbitMQ.
|
# IPv6 environment, necessary for RabbitMQ.
|
||||||
if $ipv6 {
|
if $ipv6 {
|
||||||
@ -60,6 +66,14 @@ class tripleo::profile::base::rabbitmq (
|
|||||||
} else {
|
} else {
|
||||||
$rabbit_env = $environment
|
$rabbit_env = $environment
|
||||||
}
|
}
|
||||||
|
if $inet_dist_interface {
|
||||||
|
$real_kernel_variables = merge(
|
||||||
|
$kernel_variables,
|
||||||
|
{ 'inet_dist_use_interface' => ip_to_erl_format($inet_dist_interface) },
|
||||||
|
)
|
||||||
|
} else {
|
||||||
|
$real_kernel_variables = $kernel_variables
|
||||||
|
}
|
||||||
|
|
||||||
$manage_service = hiera('rabbitmq::service_manage', true)
|
$manage_service = hiera('rabbitmq::service_manage', true)
|
||||||
if $step >= 1 {
|
if $step >= 1 {
|
||||||
@ -68,7 +82,7 @@ class tripleo::profile::base::rabbitmq (
|
|||||||
class { '::rabbitmq':
|
class { '::rabbitmq':
|
||||||
config_cluster => $manage_service,
|
config_cluster => $manage_service,
|
||||||
cluster_nodes => $nodes,
|
cluster_nodes => $nodes,
|
||||||
config_kernel_variables => $kernel_variables,
|
config_kernel_variables => $real_kernel_variables,
|
||||||
config_variables => $config_variables,
|
config_variables => $config_variables,
|
||||||
environment_variables => $rabbit_env,
|
environment_variables => $rabbit_env,
|
||||||
}
|
}
|
||||||
|
11
spec/functions/ip_to_erl_format_spec.rb
Normal file
11
spec/functions/ip_to_erl_format_spec.rb
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
require 'spec_helper'
|
||||||
|
require 'puppet'
|
||||||
|
|
||||||
|
describe 'ip_to_erl_format' do
|
||||||
|
it { should run.with_params('192.168.2.1').and_return('{192,168,2,1}') }
|
||||||
|
it { should run.with_params('0.0.0.0').and_return('{0,0,0,0}') }
|
||||||
|
it { should run.with_params('5a40:79cf:8251:5dc5:1624:3c03:3c04:9ba8').and_return('{23104,31183,33361,24005,5668,15363,15364,39848}') }
|
||||||
|
it { should run.with_params('fe80::204:acff:fe17:bf38').and_return('{65152,0,0,0,516,44287,65047,48952}') }
|
||||||
|
it { should run.with_params('::1:2').and_return('{0,0,0,0,0,0,1,2}') }
|
||||||
|
it { should run.with_params('192.256.0.0').and_raise_error(IPAddr::InvalidAddressError) }
|
||||||
|
end
|
Loading…
Reference in New Issue
Block a user