lbaas: remove lbaasv1 and enable lbaasv2 by default
Upstream has just removed lbaasv1 from openstack-lbaas (https://review.openstack.org/286381). Let's follow them and provide a working lbaas deployment for our users on Newton. - Switch-on lbaasv2 by default instead of lbaasv1 to follow what upstream Neutron is doing in https://review.openstack.org/286381 and also switch default device_driver to be neutron_lbaas.drivers.haproxy.namespace_driver.HaproxyNSDriver - remove lbaasv1 support. - enable_v1 and enable_v2 are deprecated in neutron::agents::lbaas. Change-Id: I1c032c53b61face152bb37dfac4646db11403e4e
This commit is contained in:
@@ -21,7 +21,7 @@
|
|||||||
# (optional) Defaults to 'neutron.agent.linux.interface.OVSInterfaceDriver'.
|
# (optional) Defaults to 'neutron.agent.linux.interface.OVSInterfaceDriver'.
|
||||||
#
|
#
|
||||||
# [*device_driver*]
|
# [*device_driver*]
|
||||||
# (optional) Defaults to 'neutron_lbaas.services.loadbalancer.drivers.haproxy.namespace_driver.HaproxyNSDriver'.
|
# (optional) Defaults to 'neutron_lbaas.drivers.haproxy.namespace_driver.HaproxyNSDriver'.
|
||||||
#
|
#
|
||||||
# [*user_group*]
|
# [*user_group*]
|
||||||
# (optional) The user group.
|
# (optional) The user group.
|
||||||
@@ -37,13 +37,17 @@
|
|||||||
# in the lbaas config.
|
# in the lbaas config.
|
||||||
# Defaults to false.
|
# Defaults to false.
|
||||||
#
|
#
|
||||||
|
# DEPRECATED PARAMETERS
|
||||||
|
#
|
||||||
# [*enable_v1*]
|
# [*enable_v1*]
|
||||||
# (optional) Whether to use lbaas v1 agent or not.
|
# (optional) Whether to use lbaas v1 agent or not.
|
||||||
# Defaults to true
|
# Deprecated. Will be removed in Ocata.
|
||||||
|
# Defaults to undef
|
||||||
#
|
#
|
||||||
# [*enable_v2*]
|
# [*enable_v2*]
|
||||||
# (optional) Whether to use lbaas v2 agent or not.
|
# (optional) Whether to use lbaas v2 agent or not.
|
||||||
# Defaults to false
|
# Deprecated. Will be removed in Ocata.
|
||||||
|
# Defaults to undef
|
||||||
#
|
#
|
||||||
class neutron::agents::lbaas (
|
class neutron::agents::lbaas (
|
||||||
$package_ensure = present,
|
$package_ensure = present,
|
||||||
@@ -51,24 +55,25 @@ class neutron::agents::lbaas (
|
|||||||
$manage_service = true,
|
$manage_service = true,
|
||||||
$debug = $::os_service_default,
|
$debug = $::os_service_default,
|
||||||
$interface_driver = 'neutron.agent.linux.interface.OVSInterfaceDriver',
|
$interface_driver = 'neutron.agent.linux.interface.OVSInterfaceDriver',
|
||||||
$device_driver = 'neutron_lbaas.services.loadbalancer.drivers.haproxy.namespace_driver.HaproxyNSDriver',
|
$device_driver = 'neutron_lbaas.drivers.haproxy.namespace_driver.HaproxyNSDriver',
|
||||||
$user_group = $::neutron::params::nobody_user_group,
|
$user_group = $::neutron::params::nobody_user_group,
|
||||||
$manage_haproxy_package = true,
|
$manage_haproxy_package = true,
|
||||||
$purge_config = false,
|
$purge_config = false,
|
||||||
$enable_v1 = true,
|
# DEPRECATED PARAMETERS
|
||||||
$enable_v2 = false,
|
$enable_v1 = undef,
|
||||||
|
$enable_v2 = undef,
|
||||||
) {
|
) {
|
||||||
|
|
||||||
include ::neutron::deps
|
include ::neutron::deps
|
||||||
include ::neutron::params
|
include ::neutron::params
|
||||||
|
|
||||||
if $enable_v1 and $enable_v2 {
|
if $enable_v1 or $enable_v2 {
|
||||||
fail('neutron agents LBaaS enable_v1 and enable_v2 parameters cannot both be true')
|
warning('enable_v1 and enable_v2 parameters are deprecated and will be removed in Ocata.')
|
||||||
}
|
}
|
||||||
|
|
||||||
case $device_driver {
|
case $device_driver {
|
||||||
/\.haproxy/: {
|
/\.haproxy/: {
|
||||||
Package <| title == $::neutron::params::haproxy_package |> -> Package <| title == 'neutron-lbaas-agent' |>
|
Package <| title == $::neutron::params::haproxy_package |> -> Package <| title == 'neutron-lbaasv2-agent' |>
|
||||||
if $manage_haproxy_package {
|
if $manage_haproxy_package {
|
||||||
ensure_packages([$::neutron::params::haproxy_package])
|
ensure_packages([$::neutron::params::haproxy_package])
|
||||||
}
|
}
|
||||||
@@ -92,44 +97,23 @@ class neutron::agents::lbaas (
|
|||||||
'haproxy/user_group': value => $user_group;
|
'haproxy/user_group': value => $user_group;
|
||||||
}
|
}
|
||||||
|
|
||||||
Package['neutron'] -> Package['neutron-lbaas-agent']
|
Package['neutron'] -> Package['neutron-lbaasv2-agent']
|
||||||
ensure_resource( 'package', 'neutron-lbaas-agent', {
|
ensure_resource( 'package', 'neutron-lbaasv2-agent', {
|
||||||
ensure => $package_ensure,
|
|
||||||
name => $::neutron::params::lbaas_agent_package,
|
|
||||||
tag => ['openstack', 'neutron-package'],
|
|
||||||
})
|
|
||||||
if $::osfamily == 'Debian' {
|
|
||||||
ensure_packages(['neutron-lbaasv2-package'], {
|
|
||||||
ensure => $package_ensure,
|
ensure => $package_ensure,
|
||||||
name => $::neutron::params::lbaasv2_agent_package,
|
name => $::neutron::params::lbaasv2_agent_package,
|
||||||
tag => ['openstack', 'neutron-package'],
|
tag => ['openstack', 'neutron-package'],
|
||||||
})
|
})
|
||||||
Package['neutron'] -> Package['neutron-lbaasv2-package']
|
|
||||||
}
|
|
||||||
if $manage_service {
|
|
||||||
if $enable_v1 {
|
|
||||||
$service_v1_ensure = 'running'
|
|
||||||
$service_v2_ensure = 'stopped'
|
|
||||||
} elsif $enable_v2 {
|
|
||||||
$service_v1_ensure = 'stopped'
|
|
||||||
$service_v2_ensure = 'running'
|
|
||||||
} else {
|
|
||||||
$service_v1_ensure = 'stopped'
|
|
||||||
$service_v2_ensure = 'stopped'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
service { 'neutron-lbaas-service':
|
if $manage_service {
|
||||||
ensure => $service_v1_ensure,
|
$service_ensure = 'running'
|
||||||
name => $::neutron::params::lbaas_agent_service,
|
} else {
|
||||||
enable => $enable_v1,
|
$service_ensure = 'stopped'
|
||||||
tag => 'neutron-service',
|
|
||||||
}
|
}
|
||||||
|
|
||||||
service { 'neutron-lbaasv2-service':
|
service { 'neutron-lbaasv2-service':
|
||||||
ensure => $service_v2_ensure,
|
ensure => $service_ensure,
|
||||||
name => $::neutron::params::lbaasv2_agent_service,
|
name => $::neutron::params::lbaasv2_agent_service,
|
||||||
enable => $enable_v2,
|
enable => $enabled,
|
||||||
tag => 'neutron-service',
|
tag => 'neutron-service',
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -58,10 +58,7 @@ class neutron::params {
|
|||||||
|
|
||||||
$dnsmasq_packages = ['dnsmasq', 'dnsmasq-utils']
|
$dnsmasq_packages = ['dnsmasq', 'dnsmasq-utils']
|
||||||
|
|
||||||
$lbaas_agent_package = 'openstack-neutron-lbaas'
|
$lbaasv2_agent_package = 'openstack-neutron-lbaas'
|
||||||
$lbaas_agent_service = 'neutron-lbaas-agent'
|
|
||||||
|
|
||||||
$lbaasv2_agent_package = false
|
|
||||||
$lbaasv2_agent_service = 'neutron-lbaasv2-agent'
|
$lbaasv2_agent_service = 'neutron-lbaasv2-agent'
|
||||||
|
|
||||||
$haproxy_package = 'haproxy'
|
$haproxy_package = 'haproxy'
|
||||||
@@ -143,9 +140,6 @@ class neutron::params {
|
|||||||
$dhcp_agent_package = 'neutron-dhcp-agent'
|
$dhcp_agent_package = 'neutron-dhcp-agent'
|
||||||
$dhcp_agent_service = 'neutron-dhcp-agent'
|
$dhcp_agent_service = 'neutron-dhcp-agent'
|
||||||
|
|
||||||
$lbaas_agent_package = 'neutron-lbaas-agent'
|
|
||||||
$lbaas_agent_service = 'neutron-lbaas-agent'
|
|
||||||
|
|
||||||
$lbaasv2_agent_package = 'neutron-lbaasv2-agent'
|
$lbaasv2_agent_package = 'neutron-lbaasv2-agent'
|
||||||
$lbaasv2_agent_service = 'neutron-lbaasv2-agent'
|
$lbaasv2_agent_service = 'neutron-lbaasv2-agent'
|
||||||
|
|
||||||
|
|||||||
@@ -374,9 +374,9 @@ class neutron::server (
|
|||||||
|
|
||||||
if $ensure_lbaas_package {
|
if $ensure_lbaas_package {
|
||||||
warning('$ensure_lbaas_package is deprecated. To install lbaas agent the neutron::agents::lbaas class should be used.')
|
warning('$ensure_lbaas_package is deprecated. To install lbaas agent the neutron::agents::lbaas class should be used.')
|
||||||
ensure_resource( 'package', 'neutron-lbaas-agent', {
|
ensure_resource( 'package', 'neutron-lbaasv2-agent', {
|
||||||
'ensure' => $package_ensure,
|
'ensure' => $package_ensure,
|
||||||
'name' => $::neutron::params::lbaas_agent_package,
|
'name' => $::neutron::params::lbaasv2_agent_package,
|
||||||
'tag' => ['openstack', 'neutron-package'],
|
'tag' => ['openstack', 'neutron-package'],
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -68,9 +68,9 @@ class neutron::services::lbaas (
|
|||||||
if $package_ensure {
|
if $package_ensure {
|
||||||
warning('Package ensure is deprecated. The neutron::agents::lbaas class should be used to install the agent')
|
warning('Package ensure is deprecated. The neutron::agents::lbaas class should be used to install the agent')
|
||||||
# agent package contains both agent and service resources
|
# agent package contains both agent and service resources
|
||||||
ensure_resource( 'package', 'neutron-lbaas-agent', {
|
ensure_resource( 'package', 'neutron-lbaasv2-agent', {
|
||||||
ensure => $package_ensure,
|
ensure => $package_ensure,
|
||||||
name => $::neutron::params::lbaas_agent_package,
|
name => $::neutron::params::lbaasv2_agent_package,
|
||||||
tag => ['openstack', 'neutron-package'],
|
tag => ['openstack', 'neutron-package'],
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|||||||
9
releasenotes/notes/lbaasv2-default-066d13cf24fc4c49.yaml
Normal file
9
releasenotes/notes/lbaasv2-default-066d13cf24fc4c49.yaml
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
---
|
||||||
|
upgrade:
|
||||||
|
- Switch-on lbaasv2 by default instead of lbaasv2 to follow what upstream Neutron is doing
|
||||||
|
in https://review.openstack.org/286381 and also switch default device_driver to be
|
||||||
|
neutron_lbaas.drivers.haproxy.namespace_driver.HaproxyNSDriver
|
||||||
|
|
||||||
|
deprecations:
|
||||||
|
- enable_v1 and enable_v2 are deprecated in neutron::agents::lbaas.
|
||||||
|
- LBaaS v1 deployment is not supported anymore.
|
||||||
@@ -36,11 +36,7 @@ describe 'basic neutron' do
|
|||||||
allow_overlapping_ips => true,
|
allow_overlapping_ips => true,
|
||||||
core_plugin => 'ml2',
|
core_plugin => 'ml2',
|
||||||
debug => true,
|
debug => true,
|
||||||
service_plugins => [
|
service_plugins => ['router', 'metering'],
|
||||||
'neutron.services.l3_router.l3_router_plugin.L3RouterPlugin',
|
|
||||||
'neutron_lbaas.services.loadbalancer.plugin.LoadBalancerPlugin',
|
|
||||||
'neutron.services.metering.metering_plugin.MeteringPlugin',
|
|
||||||
],
|
|
||||||
}
|
}
|
||||||
class { '::neutron::db::mysql':
|
class { '::neutron::db::mysql':
|
||||||
password => 'a_big_secret',
|
password => 'a_big_secret',
|
||||||
@@ -59,7 +55,7 @@ describe 'basic neutron' do
|
|||||||
auth_url => 'http://127.0.0.1:35357/',
|
auth_url => 'http://127.0.0.1:35357/',
|
||||||
sync_db => true,
|
sync_db => true,
|
||||||
service_providers => [
|
service_providers => [
|
||||||
'LOADBALANCER:Haproxy:neutron_lbaas.services.loadbalancer.drivers.haproxy.plugin_driver.HaproxyOnHostPluginDriver:default',
|
'LOADBALANCERV2:Haproxy:neutron_lbaas.drivers.haproxy.plugin_driver.HaproxyOnHostPluginDriver'
|
||||||
],
|
],
|
||||||
}
|
}
|
||||||
class { '::neutron::client': }
|
class { '::neutron::client': }
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ describe 'neutron::agents::lbaas' do
|
|||||||
{ :package_ensure => 'present',
|
{ :package_ensure => 'present',
|
||||||
:enabled => true,
|
:enabled => true,
|
||||||
:interface_driver => 'neutron.agent.linux.interface.OVSInterfaceDriver',
|
:interface_driver => 'neutron.agent.linux.interface.OVSInterfaceDriver',
|
||||||
:device_driver => 'neutron_lbaas.services.loadbalancer.drivers.haproxy.namespace_driver.HaproxyNSDriver',
|
:device_driver => 'neutron_lbaas.drivers.haproxy.namespace_driver.HaproxyNSDriver',
|
||||||
:manage_haproxy_package => true,
|
:manage_haproxy_package => true,
|
||||||
:purge_config => false
|
:purge_config => false
|
||||||
}
|
}
|
||||||
@@ -51,23 +51,23 @@ describe 'neutron::agents::lbaas' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
it 'installs neutron lbaas agent package' do
|
it 'installs neutron lbaas agent package' do
|
||||||
is_expected.to contain_package('neutron-lbaas-agent').with(
|
is_expected.to contain_package('neutron-lbaasv2-agent').with(
|
||||||
:name => platform_params[:lbaas_agent_package],
|
:name => platform_params[:lbaas_agent_package],
|
||||||
:ensure => p[:package_ensure],
|
:ensure => p[:package_ensure],
|
||||||
:tag => ['openstack', 'neutron-package'],
|
:tag => ['openstack', 'neutron-package'],
|
||||||
)
|
)
|
||||||
is_expected.to contain_package('neutron').with_before(/Package\[neutron-lbaas-agent\]/)
|
is_expected.to contain_package('neutron').with_before(/Package\[neutron-lbaasv2-agent\]/)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'configures neutron lbaas agent service' do
|
it 'configures neutron lbaas agent service' do
|
||||||
is_expected.to contain_service('neutron-lbaas-service').with(
|
is_expected.to contain_service('neutron-lbaasv2-service').with(
|
||||||
:name => platform_params[:lbaas_agent_service],
|
:name => platform_params[:lbaas_agent_service],
|
||||||
:enable => true,
|
:enable => true,
|
||||||
:ensure => 'running',
|
:ensure => 'running',
|
||||||
:tag => 'neutron-service',
|
:tag => 'neutron-service',
|
||||||
)
|
)
|
||||||
is_expected.to contain_service('neutron-lbaas-service').that_subscribes_to('Anchor[neutron::service::begin]')
|
is_expected.to contain_service('neutron-lbaasv2-service').that_subscribes_to('Anchor[neutron::service::begin]')
|
||||||
is_expected.to contain_service('neutron-lbaas-service').that_notifies('Anchor[neutron::service::end]')
|
is_expected.to contain_service('neutron-lbaasv2-service').that_notifies('Anchor[neutron::service::end]')
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'with manage_service as false' do
|
context 'with manage_service as false' do
|
||||||
@@ -75,7 +75,9 @@ describe 'neutron::agents::lbaas' do
|
|||||||
params.merge!(:manage_service => false)
|
params.merge!(:manage_service => false)
|
||||||
end
|
end
|
||||||
it 'should not start/stop service' do
|
it 'should not start/stop service' do
|
||||||
is_expected.to contain_service('neutron-lbaas-service').without_ensure
|
is_expected.to contain_service('neutron-lbaasv2-service').with(
|
||||||
|
:ensure => 'stopped',
|
||||||
|
)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -83,7 +85,7 @@ describe 'neutron::agents::lbaas' do
|
|||||||
shared_examples_for 'haproxy lbaas_driver' do
|
shared_examples_for 'haproxy lbaas_driver' do
|
||||||
it 'installs haproxy packages' do
|
it 'installs haproxy packages' do
|
||||||
if platform_params.has_key?(:lbaas_agent_package)
|
if platform_params.has_key?(:lbaas_agent_package)
|
||||||
is_expected.to contain_package(platform_params[:haproxy_package]).with_before(['Package[neutron-lbaas-agent]'])
|
is_expected.to contain_package(platform_params[:haproxy_package]).with_before(['Package[neutron-lbaasv2-agent]'])
|
||||||
end
|
end
|
||||||
is_expected.to contain_package(platform_params[:haproxy_package]).with(
|
is_expected.to contain_package(platform_params[:haproxy_package]).with(
|
||||||
:ensure => 'present'
|
:ensure => 'present'
|
||||||
@@ -119,9 +121,9 @@ describe 'neutron::agents::lbaas' do
|
|||||||
|
|
||||||
let :platform_params do
|
let :platform_params do
|
||||||
{ :haproxy_package => 'haproxy',
|
{ :haproxy_package => 'haproxy',
|
||||||
:lbaas_agent_package => 'neutron-lbaas-agent',
|
:lbaas_agent_package => 'neutron-lbaasv2-agent',
|
||||||
:nobody_user_group => 'nogroup',
|
:nobody_user_group => 'nogroup',
|
||||||
:lbaas_agent_service => 'neutron-lbaas-agent' }
|
:lbaas_agent_service => 'neutron-lbaasv2-agent' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'neutron lbaas agent'
|
it_configures 'neutron lbaas agent'
|
||||||
@@ -141,7 +143,7 @@ describe 'neutron::agents::lbaas' do
|
|||||||
{ :haproxy_package => 'haproxy',
|
{ :haproxy_package => 'haproxy',
|
||||||
:lbaas_agent_package => 'openstack-neutron-lbaas',
|
:lbaas_agent_package => 'openstack-neutron-lbaas',
|
||||||
:nobody_user_group => 'nobody',
|
:nobody_user_group => 'nobody',
|
||||||
:lbaas_agent_service => 'neutron-lbaas-agent' }
|
:lbaas_agent_service => 'neutron-lbaasv2-agent' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'neutron lbaas agent'
|
it_configures 'neutron lbaas agent'
|
||||||
|
|||||||
@@ -254,7 +254,7 @@ describe 'neutron::server' do
|
|||||||
)
|
)
|
||||||
end
|
end
|
||||||
it 'should install *aaS packages' do
|
it 'should install *aaS packages' do
|
||||||
is_expected.to contain_package('neutron-lbaas-agent')
|
is_expected.to contain_package('neutron-lbaasv2-agent')
|
||||||
is_expected.to contain_package('neutron-fwaas')
|
is_expected.to contain_package('neutron-fwaas')
|
||||||
is_expected.to contain_package('neutron-vpnaas-agent')
|
is_expected.to contain_package('neutron-vpnaas-agent')
|
||||||
end
|
end
|
||||||
|
|||||||
Reference in New Issue
Block a user