Make the Neutron l3 plugin use the subnetpools
The plugin creates subnetpools but does not use them when creating the default subnets. It uses CIDR values that overlap with the default pools. Change this to use the subnetpools. Change-Id: I6171c13507e420f146801d323cb1011be36c1e8c Closes-bug: 1613717
This commit is contained in:
parent
8cf4a81bfc
commit
d7a3f5c4cc
@ -149,6 +149,15 @@ function create_neutron_initial_network {
|
|||||||
neutron_plugin_create_initial_network_profile $PHYSICAL_NETWORK
|
neutron_plugin_create_initial_network_profile $PHYSICAL_NETWORK
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if is_networking_extension_supported "auto-allocated-topology"; then
|
||||||
|
if [[ "$IP_VERSION" =~ 4.* ]]; then
|
||||||
|
SUBNETPOOL_V4_ID=$(neutron --os-cloud devstack-admin --os-region "$REGION_NAME" subnetpool-create $SUBNETPOOL_NAME --default-prefixlen $SUBNETPOOL_SIZE_V4 --pool-prefix $SUBNETPOOL_PREFIX_V4 --shared --is-default=True | grep ' id ' | get_field 2)
|
||||||
|
fi
|
||||||
|
if [[ "$IP_VERSION" =~ .*6 ]]; then
|
||||||
|
SUBNETPOOL_V6_ID=$(neutron --os-cloud devstack-admin --os-region "$REGION_NAME" subnetpool-create $SUBNETPOOL_NAME --default-prefixlen $SUBNETPOOL_SIZE_V6 --pool-prefix $SUBNETPOOL_PREFIX_V6 --shared --is-default=True | grep ' id ' | get_field 2)
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
if is_provider_network; then
|
if is_provider_network; then
|
||||||
die_if_not_set $LINENO PHYSICAL_NETWORK "You must specify the PHYSICAL_NETWORK"
|
die_if_not_set $LINENO PHYSICAL_NETWORK "You must specify the PHYSICAL_NETWORK"
|
||||||
die_if_not_set $LINENO PROVIDER_NETWORK_TYPE "You must specify the PROVIDER_NETWORK_TYPE"
|
die_if_not_set $LINENO PROVIDER_NETWORK_TYPE "You must specify the PROVIDER_NETWORK_TYPE"
|
||||||
@ -156,14 +165,20 @@ function create_neutron_initial_network {
|
|||||||
die_if_not_set $LINENO NET_ID "Failure creating NET_ID for $PHYSICAL_NETWORK $project_id"
|
die_if_not_set $LINENO NET_ID "Failure creating NET_ID for $PHYSICAL_NETWORK $project_id"
|
||||||
|
|
||||||
if [[ "$IP_VERSION" =~ 4.* ]]; then
|
if [[ "$IP_VERSION" =~ 4.* ]]; then
|
||||||
SUBNET_ID=$(neutron --os-cloud devstack-admin --os-region "$REGION_NAME" subnet-create --tenant_id $project_id --ip_version 4 ${ALLOCATION_POOL:+--allocation-pool $ALLOCATION_POOL} --name $PROVIDER_SUBNET_NAME --gateway $NETWORK_GATEWAY $NET_ID $FIXED_RANGE | grep ' id ' | get_field 2)
|
if [ -z $SUBNETPOOL_V4_ID ]; then
|
||||||
|
fixed_range_v4=$FIXED_RANGE
|
||||||
|
fi
|
||||||
|
SUBNET_ID=$(neutron --os-cloud devstack-admin --os-region "$REGION_NAME" subnet-create --tenant_id $project_id --ip_version 4 ${ALLOCATION_POOL:+--allocation-pool $ALLOCATION_POOL} --name $PROVIDER_SUBNET_NAME --gateway $NETWORK_GATEWAY ${SUBNETPOOL_V4_ID:+--subnetpool $SUBNETPOOL_V4_ID} $NET_ID $fixed_range_v4 | grep ' id ' | get_field 2)
|
||||||
die_if_not_set $LINENO SUBNET_ID "Failure creating SUBNET_ID for $PROVIDER_SUBNET_NAME $project_id"
|
die_if_not_set $LINENO SUBNET_ID "Failure creating SUBNET_ID for $PROVIDER_SUBNET_NAME $project_id"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ "$IP_VERSION" =~ .*6 ]]; then
|
if [[ "$IP_VERSION" =~ .*6 ]]; then
|
||||||
die_if_not_set $LINENO IPV6_PROVIDER_FIXED_RANGE "IPV6_PROVIDER_FIXED_RANGE has not been set, but Q_USE_PROVIDERNET_FOR_PUBLIC is true and IP_VERSION includes 6"
|
die_if_not_set $LINENO IPV6_PROVIDER_FIXED_RANGE "IPV6_PROVIDER_FIXED_RANGE has not been set, but Q_USE_PROVIDERNET_FOR_PUBLIC is true and IP_VERSION includes 6"
|
||||||
die_if_not_set $LINENO IPV6_PROVIDER_NETWORK_GATEWAY "IPV6_PROVIDER_NETWORK_GATEWAY has not been set, but Q_USE_PROVIDERNET_FOR_PUBLIC is true and IP_VERSION includes 6"
|
die_if_not_set $LINENO IPV6_PROVIDER_NETWORK_GATEWAY "IPV6_PROVIDER_NETWORK_GATEWAY has not been set, but Q_USE_PROVIDERNET_FOR_PUBLIC is true and IP_VERSION includes 6"
|
||||||
SUBNET_V6_ID=$(neutron --os-cloud devstack-admin --os-region "$REGION_NAME" subnet-create --tenant_id $project_id --ip_version 6 --ipv6-address-mode $IPV6_ADDRESS_MODE --gateway $IPV6_PROVIDER_NETWORK_GATEWAY --name $IPV6_PROVIDER_SUBNET_NAME $NET_ID $IPV6_PROVIDER_FIXED_RANGE | grep 'id' | get_field 2)
|
if [ -z $SUBNETPOOL_V6_ID ]; then
|
||||||
|
fixed_range_v6=$IPV6_PROVIDER_FIXED_RANGE
|
||||||
|
fi
|
||||||
|
SUBNET_V6_ID=$(neutron --os-cloud devstack-admin --os-region "$REGION_NAME" subnet-create --tenant_id $project_id --ip_version 6 --ipv6-address-mode $IPV6_ADDRESS_MODE --gateway $IPV6_PROVIDER_NETWORK_GATEWAY --name $IPV6_PROVIDER_SUBNET_NAME ${SUBNETPOOL_V6_ID:+--subnetpool $SUBNETPOOL_V6_ID} $NET_ID $fixed_range_v6 | grep 'id' | get_field 2)
|
||||||
die_if_not_set $LINENO SUBNET_V6_ID "Failure creating SUBNET_V6_ID for $IPV6_PROVIDER_SUBNET_NAME $project_id"
|
die_if_not_set $LINENO SUBNET_V6_ID "Failure creating SUBNET_V6_ID for $IPV6_PROVIDER_SUBNET_NAME $project_id"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@ -200,14 +215,8 @@ function create_neutron_initial_network {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
EXTERNAL_NETWORK_FLAGS="--router:external"
|
EXTERNAL_NETWORK_FLAGS="--router:external"
|
||||||
if is_networking_extension_supported "auto-allocated-topology" && is_networking_extension_supported "subnet_allocation"; then
|
if is_networking_extension_supported "auto-allocated-topology"; then
|
||||||
EXTERNAL_NETWORK_FLAGS="$EXTERNAL_NETWORK_FLAGS --is-default"
|
EXTERNAL_NETWORK_FLAGS="$EXTERNAL_NETWORK_FLAGS --is-default"
|
||||||
if [[ "$IP_VERSION" =~ 4.* ]]; then
|
|
||||||
SUBNETPOOL_V4_ID=$(neutron --os-cloud devstack-admin --os-region "$REGION_NAME" subnetpool-create $SUBNETPOOL_NAME --default-prefixlen $SUBNETPOOL_SIZE_V4 --pool-prefix $SUBNETPOOL_PREFIX_V4 --shared --is-default=True | grep ' id ' | get_field 2)
|
|
||||||
fi
|
|
||||||
if [[ "$IP_VERSION" =~ .*6 ]]; then
|
|
||||||
SUBNETPOOL_V6_ID=$(neutron --os-cloud devstack-admin --os-region "$REGION_NAME" subnetpool-create $SUBNETPOOL_NAME --default-prefixlen $SUBNETPOOL_SIZE_V6 --pool-prefix $SUBNETPOOL_PREFIX_V6 --shared --is-default=True | grep ' id ' | get_field 2)
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
# Create an external network, and a subnet. Configure the external network as router gw
|
# Create an external network, and a subnet. Configure the external network as router gw
|
||||||
if [ "$Q_USE_PROVIDERNET_FOR_PUBLIC" = "True" ]; then
|
if [ "$Q_USE_PROVIDERNET_FOR_PUBLIC" = "True" ]; then
|
||||||
@ -232,11 +241,15 @@ function create_neutron_initial_network {
|
|||||||
# Create private IPv4 subnet
|
# Create private IPv4 subnet
|
||||||
function _neutron_create_private_subnet_v4 {
|
function _neutron_create_private_subnet_v4 {
|
||||||
local project_id=$1
|
local project_id=$1
|
||||||
|
if [ -z $SUBNETPOOL_V4_ID ]; then
|
||||||
|
fixed_range_v4=$FIXED_RANGE
|
||||||
|
fi
|
||||||
local subnet_params="--tenant-id $project_id "
|
local subnet_params="--tenant-id $project_id "
|
||||||
subnet_params+="--ip_version 4 "
|
subnet_params+="--ip_version 4 "
|
||||||
subnet_params+="--gateway $NETWORK_GATEWAY "
|
subnet_params+="--gateway $NETWORK_GATEWAY "
|
||||||
subnet_params+="--name $PRIVATE_SUBNET_NAME "
|
subnet_params+="--name $PRIVATE_SUBNET_NAME "
|
||||||
subnet_params+="$NET_ID $FIXED_RANGE"
|
subnet_params+="${SUBNETPOOL_V4_ID:+--subnetpool $SUBNETPOOL_V4_ID} "
|
||||||
|
subnet_params+="$NET_ID $fixed_range_v4"
|
||||||
local subnet_id
|
local subnet_id
|
||||||
subnet_id=$(neutron --os-cloud devstack-admin --os-region "$REGION_NAME" subnet-create $subnet_params | grep ' id ' | get_field 2)
|
subnet_id=$(neutron --os-cloud devstack-admin --os-region "$REGION_NAME" subnet-create $subnet_params | grep ' id ' | get_field 2)
|
||||||
die_if_not_set $LINENO subnet_id "Failure creating private IPv4 subnet for $project_id"
|
die_if_not_set $LINENO subnet_id "Failure creating private IPv4 subnet for $project_id"
|
||||||
@ -249,11 +262,15 @@ function _neutron_create_private_subnet_v6 {
|
|||||||
die_if_not_set $LINENO IPV6_RA_MODE "IPV6 RA Mode not set"
|
die_if_not_set $LINENO IPV6_RA_MODE "IPV6 RA Mode not set"
|
||||||
die_if_not_set $LINENO IPV6_ADDRESS_MODE "IPV6 Address Mode not set"
|
die_if_not_set $LINENO IPV6_ADDRESS_MODE "IPV6 Address Mode not set"
|
||||||
local ipv6_modes="--ipv6-ra-mode $IPV6_RA_MODE --ipv6-address-mode $IPV6_ADDRESS_MODE"
|
local ipv6_modes="--ipv6-ra-mode $IPV6_RA_MODE --ipv6-address-mode $IPV6_ADDRESS_MODE"
|
||||||
|
if [ -z $SUBNETPOOL_V6_ID ]; then
|
||||||
|
fixed_range_v6=$FIXED_RANGE_V6
|
||||||
|
fi
|
||||||
local subnet_params="--tenant-id $project_id "
|
local subnet_params="--tenant-id $project_id "
|
||||||
subnet_params+="--ip_version 6 "
|
subnet_params+="--ip_version 6 "
|
||||||
subnet_params+="--gateway $IPV6_PRIVATE_NETWORK_GATEWAY "
|
subnet_params+="--gateway $IPV6_PRIVATE_NETWORK_GATEWAY "
|
||||||
subnet_params+="--name $IPV6_PRIVATE_SUBNET_NAME "
|
subnet_params+="--name $IPV6_PRIVATE_SUBNET_NAME "
|
||||||
subnet_params+="$NET_ID $FIXED_RANGE_V6 $ipv6_modes"
|
subnet_params+="${SUBNETPOOL_V6_ID:+--subnetpool $SUBNETPOOL_V6_ID} "
|
||||||
|
subnet_params+="$NET_ID $fixed_range_v6 $ipv6_modes"
|
||||||
local ipv6_subnet_id
|
local ipv6_subnet_id
|
||||||
ipv6_subnet_id=$(neutron --os-cloud devstack-admin --os-region "$REGION_NAME" subnet-create $subnet_params | grep ' id ' | get_field 2)
|
ipv6_subnet_id=$(neutron --os-cloud devstack-admin --os-region "$REGION_NAME" subnet-create $subnet_params | grep ' id ' | get_field 2)
|
||||||
die_if_not_set $LINENO ipv6_subnet_id "Failure creating private IPv6 subnet for $project_id"
|
die_if_not_set $LINENO ipv6_subnet_id "Failure creating private IPv6 subnet for $project_id"
|
||||||
@ -321,7 +338,11 @@ function _neutron_configure_router_v4 {
|
|||||||
fi
|
fi
|
||||||
ROUTER_GW_IP=$(neutron --os-cloud devstack-admin --os-region "$REGION_NAME" port-list -c fixed_ips -c device_owner | grep router_gateway | awk -F'ip_address' '{ print $2 }' | cut -f3 -d\" | tr '\n' ' ')
|
ROUTER_GW_IP=$(neutron --os-cloud devstack-admin --os-region "$REGION_NAME" port-list -c fixed_ips -c device_owner | grep router_gateway | awk -F'ip_address' '{ print $2 }' | cut -f3 -d\" | tr '\n' ' ')
|
||||||
die_if_not_set $LINENO ROUTER_GW_IP "Failure retrieving ROUTER_GW_IP"
|
die_if_not_set $LINENO ROUTER_GW_IP "Failure retrieving ROUTER_GW_IP"
|
||||||
sudo ip route replace $FIXED_RANGE via $ROUTER_GW_IP
|
local replace_range=${SUBNETPOOL_PREFIX_V4}
|
||||||
|
if [[ -z "${SUBNETPOOL_V4_ID}" ]]; then
|
||||||
|
replace_range=${FIXED_RANGE}
|
||||||
|
fi
|
||||||
|
sudo ip route replace $replace_range via $ROUTER_GW_IP
|
||||||
fi
|
fi
|
||||||
_neutron_set_router_id
|
_neutron_set_router_id
|
||||||
fi
|
fi
|
||||||
@ -360,7 +381,11 @@ function _neutron_configure_router_v6 {
|
|||||||
|
|
||||||
# Configure interface for public bridge
|
# Configure interface for public bridge
|
||||||
sudo ip -6 addr replace $ipv6_ext_gw_ip/$ipv6_cidr_len dev $ext_gw_interface
|
sudo ip -6 addr replace $ipv6_ext_gw_ip/$ipv6_cidr_len dev $ext_gw_interface
|
||||||
sudo ip -6 route replace $FIXED_RANGE_V6 via $IPV6_ROUTER_GW_IP dev $ext_gw_interface
|
local replace_range=${SUBNETPOOL_PREFIX_V6}
|
||||||
|
if [[ -z "${SUBNETPOOL_V6_ID}" ]]; then
|
||||||
|
replace_range=${FIXED_RANGE_V6}
|
||||||
|
fi
|
||||||
|
sudo ip -6 route replace $replace_range via $IPV6_ROUTER_GW_IP dev $ext_gw_interface
|
||||||
fi
|
fi
|
||||||
_neutron_set_router_id
|
_neutron_set_router_id
|
||||||
fi
|
fi
|
||||||
|
Loading…
Reference in New Issue
Block a user