mtu support

This commit is contained in:
Edward Hope-Morley 2015-02-03 11:54:02 +00:00
commit 79078ab130
7 changed files with 86 additions and 10 deletions

View File

@ -1,4 +1,4 @@
branch: lp:charm-helpers branch: lp:~cts-engineering/charm-helpers/neutron-mtu
destination: hooks/charmhelpers destination: hooks/charmhelpers
include: include:
- core - core

View File

@ -23,7 +23,14 @@ from functools import partial
from charmhelpers.core.hookenv import unit_get from charmhelpers.core.hookenv import unit_get
from charmhelpers.fetch import apt_install from charmhelpers.fetch import apt_install
from charmhelpers.core.hookenv import ( from charmhelpers.core.hookenv import (
log config,
log,
INFO
)
from charmhelpers.core.host import (
list_nics,
get_nic_mtu,
set_nic_mtu
) )
try: try:
@ -365,3 +372,26 @@ def is_bridge_member(nic):
return True return True
return False return False
def configure_phy_nic_mtu(mng_ip=None):
"""Configure mtu for physical nic."""
phy_nic_mtu = config('phy-nic-mtu')
if phy_nic_mtu >= 1500:
phy_nic = None
if mng_ip is None:
mng_ip = unit_get('private-address')
for nic in list_nics(['eth', 'bond', 'br']):
if mng_ip in get_ipv4_addr(nic, fatal=False):
phy_nic = nic
# need to find the associated phy nic for bridge
if nic.startswith('br'):
for brnic in get_bridge_nics(nic):
if brnic.startswith('eth') or brnic.startswith('bond'):
phy_nic = brnic
break
break
if phy_nic is not None and phy_nic_mtu != get_nic_mtu(phy_nic):
set_nic_mtu(phy_nic, str(phy_nic_mtu), persistence=True)
log('set mtu={} for phy_nic={}'
.format(phy_nic_mtu, phy_nic), level=INFO)

View File

@ -361,7 +361,7 @@ def list_nics(nic_type):
ip_output = (line for line in ip_output if line) ip_output = (line for line in ip_output if line)
for line in ip_output: for line in ip_output:
if line.split()[1].startswith(int_type): if line.split()[1].startswith(int_type):
matched = re.search('.*: (bond[0-9]+\.[0-9]+)@.*', line) matched = re.search('.*: (' + int_type + r'[0-9]+\.[0-9]+)@.*', line)
if matched: if matched:
interface = matched.groups()[0] interface = matched.groups()[0]
else: else:
@ -371,10 +371,40 @@ def list_nics(nic_type):
return interfaces return interfaces
def set_nic_mtu(nic, mtu): def set_nic_mtu(nic, mtu, persistence=False):
'''Set MTU on a network interface''' '''Set MTU on a network interface'''
cmd = ['ip', 'link', 'set', nic, 'mtu', mtu] cmd = ['ip', 'link', 'set', nic, 'mtu', mtu]
subprocess.check_call(cmd) subprocess.check_call(cmd)
# persistence mtu configuration
if not persistence:
return
if os.path.exists("/etc/network/interfaces.d/%s.cfg" % nic):
nic_cfg_file = "/etc/network/interfaces.d/%s.cfg" % nic
else:
nic_cfg_file = "/etc/network/interfaces"
f = open(nic_cfg_file, "r")
lines = f.readlines()
found = False
length = len(lines)
for i in range(len(lines)):
lines[i] = lines[i].replace('\n', '')
if lines[i].startswith("iface %s" % nic):
found = True
lines.insert(i + 1, " up ip link set $IFACE mtu %s" % mtu)
lines.insert(i + 2, " down ip link set $IFACE mtu 1500")
if length > i + 2 and lines[i + 3].startswith(" up ip link set $IFACE mtu"):
del lines[i + 3]
if length > i + 2 and lines[i + 3].startswith(" down ip link set $IFACE mtu"):
del lines[i + 3]
break
if not found:
lines.insert(length + 1, "")
lines.insert(length + 2, "auto %s" % nic)
lines.insert(length + 3, "iface %s inet dhcp" % nic)
lines.insert(length + 4, " up ip link set $IFACE mtu %s" % mtu)
lines.insert(length + 5, " down ip link set $IFACE mtu 1500")
write_file(path=nic_cfg_file, content="\n".join(lines), perms=0o644)
def get_nic_mtu(nic): def get_nic_mtu(nic):

View File

@ -26,25 +26,31 @@ from subprocess import check_call
from charmhelpers.core.hookenv import ( from charmhelpers.core.hookenv import (
log, log,
DEBUG, DEBUG,
ERROR,
) )
def create(sysctl_dict, sysctl_file): def create(sysctl_dict, sysctl_file):
"""Creates a sysctl.conf file from a YAML associative array """Creates a sysctl.conf file from a YAML associative array
:param sysctl_dict: a dict of sysctl options eg { 'kernel.max_pid': 1337 } :param sysctl_dict: a YAML-formatted string of sysctl options eg "{ 'kernel.max_pid': 1337 }"
:type sysctl_dict: dict :type sysctl_dict: str
:param sysctl_file: path to the sysctl file to be saved :param sysctl_file: path to the sysctl file to be saved
:type sysctl_file: str or unicode :type sysctl_file: str or unicode
:returns: None :returns: None
""" """
sysctl_dict = yaml.load(sysctl_dict) try:
sysctl_dict_parsed = yaml.safe_load(sysctl_dict)
except yaml.YAMLError:
log("Error parsing YAML sysctl_dict: {}".format(sysctl_dict),
level=ERROR)
return
with open(sysctl_file, "w") as fd: with open(sysctl_file, "w") as fd:
for key, value in sysctl_dict.items(): for key, value in sysctl_dict_parsed.items():
fd.write("{}={}\n".format(key, value)) fd.write("{}={}\n".format(key, value))
log("Updating sysctl_file: %s values: %s" % (sysctl_file, sysctl_dict), log("Updating sysctl_file: %s values: %s" % (sysctl_file, sysctl_dict_parsed),
level=DEBUG) level=DEBUG)
check_call(["sysctl", "-p", sysctl_file]) check_call(["sysctl", "-p", sysctl_file])

View File

@ -26,6 +26,7 @@ def _neutron_api_settings():
'neutron_security_groups': False, 'neutron_security_groups': False,
'l2_population': True, 'l2_population': True,
'overlay_network_type': 'gre', 'overlay_network_type': 'gre',
'network_device_mtu': 1500,
} }
for rid in relation_ids('neutron-plugin-api'): for rid in relation_ids('neutron-plugin-api'):
for unit in related_units(rid): for unit in related_units(rid):
@ -36,6 +37,8 @@ def _neutron_api_settings():
'l2_population': rdata['l2-population'], 'l2_population': rdata['l2-population'],
'neutron_security_groups': rdata['neutron-security-groups'], 'neutron_security_groups': rdata['neutron-security-groups'],
'overlay_network_type': rdata['overlay-network-type'], 'overlay_network_type': rdata['overlay-network-type'],
'network_device_mtu': rdata['network-device-mtu']
if 'network-device-mtu' in rdata else 1500,
} }
# Override with configuration if set to true # Override with configuration if set to true
if config('disable-security-groups'): if config('disable-security-groups'):
@ -103,6 +106,8 @@ class OVSPluginContext(context.NeutronContext):
neutron_api_settings = _neutron_api_settings() neutron_api_settings = _neutron_api_settings()
ovs_ctxt['neutron_security_groups'] = self.neutron_security_groups ovs_ctxt['neutron_security_groups'] = self.neutron_security_groups
ovs_ctxt['l2_population'] = neutron_api_settings['l2_population'] ovs_ctxt['l2_population'] = neutron_api_settings['l2_population']
ovs_ctxt['network_device_mtu'] = \
neutron_api_settings['network_device_mtu']
ovs_ctxt['overlay_network_type'] = \ ovs_ctxt['overlay_network_type'] = \
neutron_api_settings['overlay_network_type'] neutron_api_settings['overlay_network_type']
# TODO: We need to sort out the syslog and debug/verbose options as a # TODO: We need to sort out the syslog and debug/verbose options as a

View File

@ -1,4 +1,4 @@
# grizzly # icehouse
############################################################################### ###############################################################################
# [ WARNING ] # [ WARNING ]
# Configuration file maintained by Juju. Local changes may be overwritten. # Configuration file maintained by Juju. Local changes may be overwritten.
@ -12,6 +12,7 @@ state_path = /var/lib/neutron
lock_path = $state_path/lock lock_path = $state_path/lock
bind_host = 0.0.0.0 bind_host = 0.0.0.0
bind_port = 9696 bind_port = 9696
network_device_mtu = {{ network_device_mtu }}
{% if core_plugin -%} {% if core_plugin -%}
core_plugin = {{ core_plugin }} core_plugin = {{ core_plugin }}

View File

@ -90,6 +90,7 @@ class OVSPluginContextTest(CharmTestCase):
self.relation_ids.return_value = ['rid2'] self.relation_ids.return_value = ['rid2']
self.test_relation.set({'neutron-security-groups': True, self.test_relation.set({'neutron-security-groups': True,
'l2-population': True, 'l2-population': True,
'network-device-mtu': 1500,
'overlay-network-type': 'gre', 'overlay-network-type': 'gre',
}) })
self.get_host_ip.return_value = '127.0.0.15' self.get_host_ip.return_value = '127.0.0.15'
@ -100,6 +101,7 @@ class OVSPluginContextTest(CharmTestCase):
'neutron_security_groups': True, 'neutron_security_groups': True,
'verbose': True, 'verbose': True,
'local_ip': '127.0.0.15', 'local_ip': '127.0.0.15',
'network_device_mtu': 1500,
'config': 'neutron.randomconfig', 'config': 'neutron.randomconfig',
'use_syslog': True, 'use_syslog': True,
'network_manager': 'neutron', 'network_manager': 'neutron',
@ -143,6 +145,7 @@ class OVSPluginContextTest(CharmTestCase):
self.relation_ids.return_value = ['rid2'] self.relation_ids.return_value = ['rid2']
self.test_relation.set({'neutron-security-groups': True, self.test_relation.set({'neutron-security-groups': True,
'l2-population': True, 'l2-population': True,
'network-device-mtu': 1500,
'overlay-network-type': 'gre', 'overlay-network-type': 'gre',
}) })
self.get_host_ip.return_value = '127.0.0.15' self.get_host_ip.return_value = '127.0.0.15'
@ -153,6 +156,7 @@ class OVSPluginContextTest(CharmTestCase):
'neutron_security_groups': False, 'neutron_security_groups': False,
'verbose': True, 'verbose': True,
'local_ip': '127.0.0.15', 'local_ip': '127.0.0.15',
'network_device_mtu': 1500,
'config': 'neutron.randomconfig', 'config': 'neutron.randomconfig',
'use_syslog': True, 'use_syslog': True,
'network_manager': 'neutron', 'network_manager': 'neutron',