← Back to team overview

yahoo-eng-team team mailing list archive

[Bug 2110225] [NEW] Floating IPs attached to Octavia LB VIPs are not reachable across routers using different external subnets (OVN + Octavia)

 

You have been subscribed to a public bug:

Hi Everyone!

We were facing an issue when extending the Openstack public network
range by adding a new subnet, by looking the comments of that launchpad
bug:

https://bugs.launchpad.net/neutron/+bug/1605343
Seems like the way to do it is to add a newer subnet, but doing so we encounter the following issue:


When using Openstack with OVN networking and Octavia LBaaS, creating routers with different external gateway subnets (e.g.. public-subnet and public-subnet-2) causes load balancer VIPs to become unreachable across subnets from VMs on the same public-subnet

Reproduction Steps:
1) Create two public subnets (public-subnet, public-subnet-2) on the same external network

2) Create two routers

router1 with external gateway set to public-subnet-2
router2 with external gateway set to public-subnet
3) Attach internal networks (private, private-2) to each router

4) Launch VMs in each subnet and deploy web servers

5) Create two Octavia load balancers:

subnet1_lb1 in private network
subnet2_lb1 in private-2 network
Assign floating IPs to the VIP ports of both load balancers

6) From each VM, try accessing subnet1_lb1 and subnet2_lb1

Observed Behavior:
>From subnet1_node1 (172.24.4.100) behind router R1 (172.24.5.X subnet) we are able to reach the Octavia LB subnet1_lb1 (172.24.4.200) ✅
>From subnet1_node1 (172.24.4.100) behind router R1 (172.24.5.X subnet) we are not able to reach the Octavia LB subnet1_lb2 (172.24.5.200) ❌

>From subnet2_node1 (172.24.5.100) behind router R2 (172.24.4.X subnet) we are able to reach the Octavia LB subnet2_lb1 (172.24.5.200) ✅
>From subnet2_node1 (172.24.5.100) behind router R2 (172.24.4.X subnet) we are not able to reach the Octavia LB subnet1_lb1 (172.24.4.200) ❌

If we put those in a matrix:
Source VM     Router (Gateway Subnet)           Target LB   VIP            Expected  Observed Result
subnet1_node1 R1 (public-subnet-2 / 172.24.5.X) subnet1_lb1 (172.24.4.200) Reachable 200.     ✅
subnet1_node1 R1 (public-subnet-2 / 172.24.5.X) subnet2_lb1 (172.24.5.200) Reachable Timeout  ❌
subnet2_node1 R2 (public-subnet / 172.24.4.X)   subnet2_lb1 (172.24.5.200) Reachable 200.     ✅
subnet2_node1 R2 (public-subnet / 172.24.4.X).  subnet1_lb1 (172.24.4.200) Reachable Timeout  ❌

We clearly see that a VM from a different subnet tries to reach a
loadbalancer via the LB floating IP, the LB is not reachable if the
router (connecting the LB to the public network) external IP is in a
different range than the LB floating IP.

Expected Behavior:
All VMs, regardless of which subnet/router they are connected to, should be able to reach any VIP exposed via floating IP

Environment:
OpenStack with OVN (replicable on latest version with Devstack)

Below i'll attach the scripts to replicate it on a freshly created
Devstack instance

Feel free to reach out for any further detail

** Affects: neutron
     Importance: Undecided
         Status: New

-- 
Floating IPs attached to Octavia LB VIPs are not reachable across routers using different external subnets (OVN + Octavia)
https://bugs.launchpad.net/bugs/2110225
You received this bug notification because you are a member of Yahoo! Engineering Team, which is subscribed to neutron.