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.
|
||||
# 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*]
|
||||
# (Optional) Array of host(s) for RabbitMQ nodes.
|
||||
# Defaults to hiera('rabbitmq_node_names', []).
|
||||
@ -48,6 +53,7 @@ class tripleo::profile::base::rabbitmq (
|
||||
$environment = hiera('rabbitmq_environment'),
|
||||
$ipv6 = str2bool(hiera('rabbit_ipv6', false)),
|
||||
$kernel_variables = hiera('rabbitmq_kernel_variables'),
|
||||
$inet_dist_interface = hiera('rabbitmq::interface', undef),
|
||||
$nodes = hiera('rabbitmq_node_names', []),
|
||||
$step = hiera('step'),
|
||||
) {
|
||||
@ -60,6 +66,14 @@ class tripleo::profile::base::rabbitmq (
|
||||
} else {
|
||||
$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)
|
||||
if $step >= 1 {
|
||||
@ -68,7 +82,7 @@ class tripleo::profile::base::rabbitmq (
|
||||
class { '::rabbitmq':
|
||||
config_cluster => $manage_service,
|
||||
cluster_nodes => $nodes,
|
||||
config_kernel_variables => $kernel_variables,
|
||||
config_kernel_variables => $real_kernel_variables,
|
||||
config_variables => $config_variables,
|
||||
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