Avoid setting IPADDR=0.0.0.0

Configuring network interfaces with IPADDR=0.0.0.0 may fail with:
Error, some other host (FF:FF:FF:FF:FF:FF) already uses address 0.0.0.0.

Change-Id: I908dc3320cb1dce7a040a1dbfeac414ace22d6e3
Co-Authored-By: Bartosz Bezak <bartosz@stackhpc.com>
Story: 2007900
Task: 40289
This commit is contained in:
Pierre Riteau 2020-09-16 15:28:54 +02:00
parent 84f98f4c04
commit 2606c23812
2 changed files with 18 additions and 6 deletions

View File

@ -200,11 +200,13 @@ def net_interface_obj(context, name, inventory_hostname=None):
"Network interface for network '%s' on host '%s' not found" % "Network interface for network '%s' on host '%s' not found" %
(name, inventory_hostname)) (name, inventory_hostname))
ip = net_ip(context, name, inventory_hostname) ip = net_ip(context, name, inventory_hostname)
if ip is None:
ip = '0.0.0.0'
cidr = net_cidr(context, name, inventory_hostname) cidr = net_cidr(context, name, inventory_hostname)
netmask = net_mask(context, name, inventory_hostname) netmask = net_mask(context, name, inventory_hostname)
gateway = net_gateway(context, name, inventory_hostname) gateway = net_gateway(context, name, inventory_hostname)
if ip is None:
ip = ''
gateway = None
netmask = None
vlan = net_vlan(context, name, inventory_hostname) vlan = net_vlan(context, name, inventory_hostname)
mtu = net_mtu(context, name, inventory_hostname) mtu = net_mtu(context, name, inventory_hostname)
routes = net_routes(context, name, inventory_hostname) routes = net_routes(context, name, inventory_hostname)
@ -248,11 +250,13 @@ def net_bridge_obj(context, name, inventory_hostname=None):
"Network interface for network '%s' on host '%s' not found" % "Network interface for network '%s' on host '%s' not found" %
(name, inventory_hostname)) (name, inventory_hostname))
ip = net_ip(context, name, inventory_hostname) ip = net_ip(context, name, inventory_hostname)
if ip is None:
ip = '0.0.0.0'
cidr = net_cidr(context, name, inventory_hostname) cidr = net_cidr(context, name, inventory_hostname)
netmask = net_mask(context, name, inventory_hostname) netmask = net_mask(context, name, inventory_hostname)
gateway = net_gateway(context, name, inventory_hostname) gateway = net_gateway(context, name, inventory_hostname)
if ip is None:
ip = ''
gateway = None
netmask = None
vlan = net_vlan(context, name, inventory_hostname) vlan = net_vlan(context, name, inventory_hostname)
mtu = net_mtu(context, name, inventory_hostname) mtu = net_mtu(context, name, inventory_hostname)
ports = net_bridge_ports(context, name, inventory_hostname) ports = net_bridge_ports(context, name, inventory_hostname)
@ -298,11 +302,13 @@ def net_bond_obj(context, name, inventory_hostname=None):
"Network interface for network '%s' on host '%s' not found" % "Network interface for network '%s' on host '%s' not found" %
(name, inventory_hostname)) (name, inventory_hostname))
ip = net_ip(context, name, inventory_hostname) ip = net_ip(context, name, inventory_hostname)
if ip is None:
ip = '0.0.0.0'
cidr = net_cidr(context, name, inventory_hostname) cidr = net_cidr(context, name, inventory_hostname)
netmask = net_mask(context, name, inventory_hostname) netmask = net_mask(context, name, inventory_hostname)
gateway = net_gateway(context, name, inventory_hostname) gateway = net_gateway(context, name, inventory_hostname)
if ip is None:
ip = ''
gateway = None
netmask = None
vlan = net_vlan(context, name, inventory_hostname) vlan = net_vlan(context, name, inventory_hostname)
mtu = net_mtu(context, name, inventory_hostname) mtu = net_mtu(context, name, inventory_hostname)
mode = net_bond_mode(context, name, inventory_hostname) mode = net_bond_mode(context, name, inventory_hostname)

View File

@ -0,0 +1,6 @@
---
fixes:
- |
Fixes issues when network interfaces are configured without IP addresses.
See `story 2007900 <https://storyboard.openstack.org/#!/story/2007900>`__
for details.