Add systemd init support for deploy from source

systemd is used instead of upstart by default since Ubuntu 15.10
(Wily).  This adds systemd init file support for nova services
that are deployed from source.

Change-Id: I784e6b9908222995c56c9f3c06cc54f0254d4761
This commit is contained in:
Corey Bryant 2016-06-23 20:40:02 +00:00 committed by James Page
parent 7491779846
commit 21b20ccf14
24 changed files with 918 additions and 273 deletions

View File

@ -8,6 +8,7 @@ from charmhelpers.core.host import (
add_user_to_group, add_user_to_group,
lsb_release, lsb_release,
mkdir, mkdir,
service,
service_running, service_running,
service_stop, service_stop,
service_restart, service_restart,
@ -42,13 +43,15 @@ from charmhelpers.contrib.hahelpers.cluster import (
from charmhelpers.contrib.openstack.utils import ( from charmhelpers.contrib.openstack.utils import (
configure_installation_source, configure_installation_source,
get_os_codename_install_source, get_os_codename_install_source,
git_install_requested,
git_clone_and_install, git_clone_and_install,
git_default_repos, git_default_repos,
git_src_dir, git_generate_systemd_init_files,
git_install_requested,
git_pip_venv_dir, git_pip_venv_dir,
git_src_dir,
get_hostname, get_hostname,
make_assess_status_func, make_assess_status_func,
os_release,
pause_unit, pause_unit,
resume_unit, resume_unit,
) )
@ -171,6 +174,7 @@ BASE_GIT_PACKAGES = [
'libxml2-dev', 'libxml2-dev',
'libxslt1-dev', 'libxslt1-dev',
'libyaml-dev', 'libyaml-dev',
'openstack-pkg-tools',
'python-dev', 'python-dev',
'python-pip', 'python-pip',
'python-setuptools', 'python-setuptools',
@ -189,6 +193,7 @@ GIT_PACKAGE_BLACKLIST = [
'neutron-plugin-cisco', 'neutron-plugin-cisco',
'neutron-plugin-metering-agent', 'neutron-plugin-metering-agent',
'neutron-plugin-openvswitch-agent', 'neutron-plugin-openvswitch-agent',
'neutron-openvswitch-agent',
'neutron-vpn-agent', 'neutron-vpn-agent',
'python-neutron-fwaas', 'python-neutron-fwaas',
'python-oslo.config', 'python-oslo.config',
@ -863,6 +868,8 @@ def git_pre_install():
'/var/lib/neutron', '/var/lib/neutron',
'/var/lib/neutron/lock', '/var/lib/neutron/lock',
'/var/log/neutron', '/var/log/neutron',
'/var/lib/nova',
'/var/log/nova',
] ]
logs = [ logs = [
@ -890,6 +897,11 @@ def git_pre_install():
add_group('neutron', system_group=True) add_group('neutron', system_group=True)
add_user_to_group('neutron', 'neutron') add_user_to_group('neutron', 'neutron')
adduser('nova', shell='/bin/bash', system_user=True)
subprocess.check_call(['usermod', '--home', '/var/lib/nova', 'nova'])
add_group('nova', system_group=True)
add_user_to_group('nova', 'nova')
for d in dirs: for d in dirs:
mkdir(d, owner='neutron', group='neutron', perms=0755, force=False) mkdir(d, owner='neutron', group='neutron', perms=0755, force=False)
@ -930,6 +942,8 @@ def git_post_install(projects_yaml):
render('git/neutron_sudoers', render('git/neutron_sudoers',
'/etc/sudoers.d/neutron_sudoers', {}, perms=0o440) '/etc/sudoers.d/neutron_sudoers', {}, perms=0o440)
render('git/nova_sudoers',
'/etc/sudoers.d/nova_sudoers', {}, perms=0o440)
render('git/cron.d/neutron-dhcp-agent-netns-cleanup', render('git/cron.d/neutron-dhcp-agent-netns-cleanup',
'/etc/cron.d/neutron-dhcp-agent-netns-cleanup', {}, perms=0o755) '/etc/cron.d/neutron-dhcp-agent-netns-cleanup', {}, perms=0o755)
render('git/cron.d/neutron-l3-agent-netns-cleanup', render('git/cron.d/neutron-l3-agent-netns-cleanup',
@ -937,9 +951,43 @@ def git_post_install(projects_yaml):
render('git/cron.d/neutron-lbaas-agent-netns-cleanup', render('git/cron.d/neutron-lbaas-agent-netns-cleanup',
'/etc/cron.d/neutron-lbaas-agent-netns-cleanup', {}, perms=0o755) '/etc/cron.d/neutron-lbaas-agent-netns-cleanup', {}, perms=0o755)
bin_dir = os.path.join(git_pip_venv_dir(projects_yaml), 'bin')
# Use systemd init units/scripts from ubuntu wily onward
if lsb_release()['DISTRIB_RELEASE'] >= '15.10':
templates_dir = os.path.join(charm_dir(), 'templates/git')
daemons = ['neutron-dhcp-agent', 'neutron-l3-agent',
'neutron-lbaas-agent', 'neutron-lbaasv2-agent',
'neutron-linuxbridge-agent', 'neutron-linuxbridge-cleanup',
'neutron-macvtap-agent', 'neutron-metadata-agent',
'neutron-metering-agent', 'neutron-openvswitch-agent',
'neutron-ovs-cleanup', 'neutron-server',
'neutron-sriov-nic-agent', 'neutron-vpn-agent',
'nova-api-metadata']
for daemon in daemons:
neutron_context = {
'daemon_path': os.path.join(bin_dir, daemon),
}
filename = daemon
if daemon == 'neutron-sriov-nic-agent':
filename = 'neutron-sriov-agent'
elif daemon == 'neutron-openvswitch-agent':
if os_release('neutron-common') < 'mitaka':
filename = 'neutron-plugin-openvswitch-agent'
template_file = 'git/{}.init.in.template'.format(filename)
init_in_file = '{}.init.in'.format(filename)
render(template_file, os.path.join(templates_dir, init_in_file),
neutron_context, perms=0o644)
git_generate_systemd_init_files(templates_dir)
for daemon in daemons:
filename = daemon
if daemon == 'neutron-openvswitch-agent':
if os_release('neutron-common') < 'mitaka':
filename = 'neutron-plugin-openvswitch-agent'
service('enable', filename)
else:
service_name = 'quantum-gateway' service_name = 'quantum-gateway'
user_name = 'neutron' user_name = 'neutron'
bin_dir = os.path.join(git_pip_venv_dir(projects_yaml), 'bin')
neutron_api_context = { neutron_api_context = {
'service_description': 'Neutron API server', 'service_description': 'Neutron API server',
'service_name': service_name, 'service_name': service_name,
@ -1014,7 +1062,8 @@ def git_post_install(projects_yaml):
'user_name': user_name, 'user_name': user_name,
'start_dir': '/var/lib/neutron', 'start_dir': '/var/lib/neutron',
'process_name': 'neutron-restproxy-agent', 'process_name': 'neutron-restproxy-agent',
'executable_name': os.path.join(bin_dir, 'neutron-restproxy-agent'), 'executable_name': os.path.join(bin_dir,
'neutron-restproxy-agent'),
'config_files': ['/etc/neutron/neutron.conf', 'config_files': ['/etc/neutron/neutron.conf',
'/etc/neutron/plugins/bigswitch/restproxy.ini'], '/etc/neutron/plugins/bigswitch/restproxy.ini'],
'log_file': '/var/log/neutron/bigswitch-agent.log', 'log_file': '/var/log/neutron/bigswitch-agent.log',
@ -1026,7 +1075,8 @@ def git_post_install(projects_yaml):
'start_dir': '/var/lib/neutron', 'start_dir': '/var/lib/neutron',
'process_name': 'neutron-ibm-agent', 'process_name': 'neutron-ibm-agent',
'executable_name': os.path.join(bin_dir, 'neutron-ibm-agent'), 'executable_name': os.path.join(bin_dir, 'neutron-ibm-agent'),
'config_files': ['/etc/neutron/neutron.conf', 'config_files':
['/etc/neutron/neutron.conf',
'/etc/neutron/plugins/ibm/sdnve_neutron_plugin.ini'], '/etc/neutron/plugins/ibm/sdnve_neutron_plugin.ini'],
'log_file': '/var/log/neutron/ibm-agent.log', 'log_file': '/var/log/neutron/ibm-agent.log',
} }
@ -1036,7 +1086,8 @@ def git_post_install(projects_yaml):
'user_name': user_name, 'user_name': user_name,
'start_dir': '/var/lib/neutron', 'start_dir': '/var/lib/neutron',
'process_name': 'neutron-linuxbridge-agent', 'process_name': 'neutron-linuxbridge-agent',
'executable_name': os.path.join(bin_dir, 'neutron-linuxbridge-agent'), 'executable_name': os.path.join(bin_dir,
'neutron-linuxbridge-agent'),
'config_files': ['/etc/neutron/neutron.conf', 'config_files': ['/etc/neutron/neutron.conf',
'/etc/neutron/plugins/ml2/ml2_conf.ini'], '/etc/neutron/plugins/ml2/ml2_conf.ini'],
'log_file': '/var/log/neutron/linuxbridge-agent.log', 'log_file': '/var/log/neutron/linuxbridge-agent.log',
@ -1069,7 +1120,8 @@ def git_post_install(projects_yaml):
'start_dir': '/var/lib/neutron', 'start_dir': '/var/lib/neutron',
'process_name': 'neutron-nvsd-agent', 'process_name': 'neutron-nvsd-agent',
'executable_name': os.path.join(bin_dir, 'neutron-nvsd-agent'), 'executable_name': os.path.join(bin_dir, 'neutron-nvsd-agent'),
'config_files': ['/etc/neutron/neutron.conf', 'config_files':
['/etc/neutron/neutron.conf',
'/etc/neutron/plugins/oneconvergence/nvsdplugin.ini'], '/etc/neutron/plugins/oneconvergence/nvsdplugin.ini'],
'log_file': '/var/log/neutron/nvsd-agent.log', 'log_file': '/var/log/neutron/nvsd-agent.log',
} }
@ -1090,7 +1142,8 @@ def git_post_install(projects_yaml):
'user_name': user_name, 'user_name': user_name,
'start_dir': '/var/lib/neutron', 'start_dir': '/var/lib/neutron',
'process_name': 'neutron-openvswitch-agent', 'process_name': 'neutron-openvswitch-agent',
'executable_name': os.path.join(bin_dir, 'neutron-openvswitch-agent'), 'executable_name': os.path.join(bin_dir,
'neutron-openvswitch-agent'),
'config_files': ['/etc/neutron/neutron.conf', 'config_files': ['/etc/neutron/neutron.conf',
'/etc/neutron/plugins/ml2/ml2_conf.ini'], '/etc/neutron/plugins/ml2/ml2_conf.ini'],
'log_file': '/var/log/neutron/openvswitch-agent.log', 'log_file': '/var/log/neutron/openvswitch-agent.log',
@ -1112,7 +1165,8 @@ def git_post_install(projects_yaml):
'user_name': user_name, 'user_name': user_name,
'start_dir': '/var/lib/neutron', 'start_dir': '/var/lib/neutron',
'process_name': 'neutron-sriov-nic-agent', 'process_name': 'neutron-sriov-nic-agent',
'executable_name': os.path.join(bin_dir, 'neutron-sriov-nic-agent'), 'executable_name': os.path.join(bin_dir,
'neutron-sriov-nic-agent'),
'config_files': ['/etc/neutron/neutron.conf', 'config_files': ['/etc/neutron/neutron.conf',
'/etc/neutron/plugins/ml2/ml2_conf_sriov'], '/etc/neutron/plugins/ml2/ml2_conf_sriov'],
'log_file': '/var/log/neutron/sriov-agent.log', 'log_file': '/var/log/neutron/sriov-agent.log',
@ -1128,8 +1182,20 @@ def git_post_install(projects_yaml):
'/etc/neutron/fwaas_driver.ini'], '/etc/neutron/fwaas_driver.ini'],
'log_file': '/var/log/neutron/vpn_agent.log', 'log_file': '/var/log/neutron/vpn_agent.log',
} }
service_name = 'nova-compute'
nova_user = 'nova'
start_dir = '/var/lib/nova'
nova_conf = '/etc/nova/nova.conf'
nova_api_metadata_context = {
'service_description': 'Nova Metadata API server',
'service_name': service_name,
'user_name': nova_user,
'start_dir': start_dir,
'process_name': 'nova-api-metadata',
'executable_name': os.path.join(bin_dir, 'nova-api-metadata'),
'config_files': [nova_conf],
}
# NOTE(coreycb): Needs systemd support
templates_dir = 'hooks/charmhelpers/contrib/openstack/templates' templates_dir = 'hooks/charmhelpers/contrib/openstack/templates'
templates_dir = os.path.join(charm_dir(), templates_dir) templates_dir = os.path.join(charm_dir(), templates_dir)
render('git/upstart/neutron-agent.upstart', render('git/upstart/neutron-agent.upstart',
@ -1182,10 +1248,16 @@ def git_post_install(projects_yaml):
'/etc/init/neutron-plugin-openflow-agent.conf', '/etc/init/neutron-plugin-openflow-agent.conf',
neutron_plugin_openflow_context, perms=0o644, neutron_plugin_openflow_context, perms=0o644,
templates_dir=templates_dir) templates_dir=templates_dir)
if os_release('neutron-common') < 'mitaka':
render('git.upstart', render('git.upstart',
'/etc/init/neutron-plugin-openvswitch-agent.conf', '/etc/init/neutron-plugin-openvswitch-agent.conf',
neutron_plugin_openvswitch_context, perms=0o644, neutron_plugin_openvswitch_context, perms=0o644,
templates_dir=templates_dir) templates_dir=templates_dir)
else:
render('git.upstart',
'/etc/init/neutron-openvswitch-agent.conf',
neutron_plugin_openvswitch_context, perms=0o644,
templates_dir=templates_dir)
render('git.upstart', render('git.upstart',
'/etc/init/neutron-plugin-ryu-agent.conf', '/etc/init/neutron-plugin-ryu-agent.conf',
neutron_plugin_ryu_context, perms=0o644, neutron_plugin_ryu_context, perms=0o644,
@ -1200,6 +1272,10 @@ def git_post_install(projects_yaml):
render('git/upstart/neutron-agent.upstart', render('git/upstart/neutron-agent.upstart',
'/etc/init/neutron-vpn-agent.conf', '/etc/init/neutron-vpn-agent.conf',
neutron_vpn_agent_context, perms=0o644) neutron_vpn_agent_context, perms=0o644)
render('git.upstart',
'/etc/init/nova-api-metadata.conf',
nova_api_metadata_context, perms=0o644,
templates_dir=templates_dir)
def get_optional_interfaces(): def get_optional_interfaces():

View File

@ -0,0 +1,24 @@
#!/bin/sh
### BEGIN INIT INFO
# Provides: neutron-dhcp-agent
# Required-Start: $network $local_fs $remote_fs $syslog
# Required-Stop: $remote_fs
# Should-Start: mysql postgresql rabbitmq-server keystone neutron-ovs-cleanup
# Should-Stop: mysql postgresql rabbitmq-server keystone
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Neutron DHCP agent
# Description: Provide DHCP agent for neutron
### END INIT INFO
# Author: Mehdi Abaakouk <sileht@sileht.net>
# PATH should only include /usr/* if it runs after the mountnfs.sh script
PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="OpenStack Neutron DHCP agent"
PROJECT_NAME=neutron
NAME=${PROJECT_NAME}-dhcp-agent
DAEMON={{ daemon_path }}
# --config-file=/etc/neutron/neutron.conf will be appended
# to DAEMON_ARGS later by openstack-pkg-tools
DAEMON_ARGS="--config-file=/etc/neutron/dhcp_agent.ini"

View File

@ -0,0 +1,25 @@
#!/bin/sh
### BEGIN INIT INFO
# Provides: neutron-l3-agent
# Required-Start: $network $local_fs $remote_fs $syslog
# Required-Stop: $remote_fs
# Should-Start: mysql postgresql rabbitmq-server keystone openvswitch-switch neutron-ovs-cleanup
# Should-Stop: mysql postgresql rabbitmq-server keystone openvswitch-switch
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Neutron L3 agent
# Description: Provide L3 agent for neutron
### END INIT INFO
# Authors: Mehdi Abaakouk <sileht@sileht.net>
# Thomas Goirand <zigo@debian.org>
# PATH should only include /usr/* if it runs after the mountnfs.sh script
PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="OpenStack Neutron L3 agent"
PROJECT_NAME=neutron
NAME=${PROJECT_NAME}-l3-agent
DAEMON={{ daemon_path }}
# --config-file=/etc/neutron/neutron.conf will be appended
# to DAEMON_ARGS later by openstack-pkg-tools
DAEMON_ARGS="--config-file=/etc/neutron/l3_agent.ini --config-file=/etc/neutron/fwaas_driver.ini"

View File

@ -0,0 +1,24 @@
#!/bin/sh
### BEGIN INIT INFO
# Provides: neutron-lbaas-agent
# Required-Start: $network $local_fs $remote_fs $syslog
# Required-Stop: $remote_fs
# Should-Start: mysql postgresql rabbitmq-server keystone
# Should-Stop: mysql postgresql rabbitmq-server keystone
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Neutron LBaaS agent
# Description: Provide LBaaS agent for neutron
### END INIT INFO
# Author: Thomas Goirand <zigo@debian.org>
# PATH should only include /usr/* if it runs after the mountnfs.sh script
PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="OpenStack Neutron LBaaS agent"
PROJECT_NAME=neutron
NAME=${PROJECT_NAME}-lbaas-agent
DAEMON={{ daemon_path }}
# --config-file=/etc/neutron/neutron.conf will be happened
# to DAEMON_ARGS later by openstack-pkg-tools
DAEMON_ARGS="--config-file=/etc/neutron/lbaas_agent.ini"

View File

@ -0,0 +1,24 @@
#!/bin/sh
### BEGIN INIT INFO
# Provides: neutron-lbaasv2-agent
# Required-Start: $network $local_fs $remote_fs $syslog
# Required-Stop: $remote_fs
# Should-Start: mysql postgresql rabbitmq-server keystone
# Should-Stop: mysql postgresql rabbitmq-server keystone
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Neutron LBaaS v2 agent
# Description: Provide LBaaS v2 agent for neutron
### END INIT INFO
# Author: Corey Bryant <corey.bryant@canonical.com>
# PATH should only include /usr/* if it runs after the mountnfs.sh script
PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="OpenStack Neutron LBaaSv2 agent"
PROJECT_NAME=neutron
NAME=${PROJECT_NAME}-lbaasv2-agent
DAEMON={{ daemon_path }}
# --config-file=/etc/neutron/neutron.conf will be happened
# to DAEMON_ARGS later by openstack-pkg-tools
DAEMON_ARGS="--config-file=/etc/neutron/lbaas_agent.ini"

View File

@ -0,0 +1,24 @@
#!/bin/sh
### BEGIN INIT INFO
# Provides: neutron-linuxbridge-agent
# Required-Start: $network $local_fs $remote_fs $syslog
# Required-Stop: $remote_fs
# Should-Start: mysql postgresql rabbitmq-server keystone neutron-linuxbridge-cleanup
# Should-Stop: mysql postgresql rabbitmq-server keystone
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Neutron LinuxBridge Agent
# Description: Agent to use within neutron linuxbridge client
### END INIT INFO
# Author: Ghe Rivero <ghe.rivero@stackops.com>
# PATH should only include /usr/* if it runs after the mountnfs.sh script
PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="Openstack Neutron LinuxBridge Agent"
PROJECT_NAME=neutron
NAME=${PROJECT_NAME}-linuxbridge-agent
DAEMON={{ daemon_path }}
# --config-file=/etc/neutron/neutron.conf will be appended
# to DAEMON_ARGS later by openstack-pkg-tools
DAEMON_ARGS="--config-file=/etc/neutron/plugins/ml2/linuxbridge_agent.ini"

View File

@ -0,0 +1,19 @@
[Unit]
Description=Openstack Neutron Linux Bridge Agent
After=mysql.service postgresql.service rabbitmq-server.service keystone.service
Requires=neutron-linuxbridge-cleanup.service
[Service]
User=neutron
Group=neutron
WorkingDirectory=/var/lib/neutron
PermissionsStartOnly=true
ExecStartPre=/bin/mkdir -p /var/lock/neutron /var/log/neutron /var/lib/neutron
ExecStartPre=/bin/chown neutron:neutron /var/lock/neutron /var/log/neutron /var/lib/neutron
ExecStart=/etc/init.d/neutron-linuxbridge-agent systemd-start
Restart=on-failure
LimitNOFILE=65535
[Install]
WantedBy=multi-user.target

View File

@ -0,0 +1,19 @@
#!/bin/sh
### BEGIN INIT INFO
# Provides: neutron-linuxbridge-cleanup
# Required-Start: $network $local_fs $remote_fs $syslog
# Required-Stop: $remote_fs
# Should-Start:
# Should-Stop:
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Neutron Linux Bridge Cleanup
# Description: Linux Bridge Cleanup for OpenStack Neutron
### END INIT INFO
# Authors: Corey Bryant <corey.bryant@canonical.com>
DESC="OpenStack Neutron Linux bridge cleanup"
PROJECT_NAME=neutron
NAME=${PROJECT_NAME}-linuxbridge-cleanup
DAEMON={{ daemon_path }}

View File

@ -0,0 +1,17 @@
[Unit]
Description=OpenStack Neutron Linux bridge cleanup
[Service]
type=oneshot
User=neutron
Group=neutron
WorkingDirectory=/var/lib/neutron
PermissionsStartOnly=true
ExecStartPre=/bin/mkdir -p /var/lock/neutron /var/log/neutron /var/lib/neutron
ExecStartPre=/bin/chown neutron:neutron /var/lock/neutron /var/log/neutron /var/lib/neutron
ExecStart=/etc/init.d/neutron-linuxbridge-cleanup systemd-start
RemainAfterExit=yes
[Install]
WantedBy=multi-user.target

View File

@ -0,0 +1,24 @@
#!/bin/sh
### BEGIN INIT INFO
# Provides: neutron-macvtap-agent
# Required-Start: $network $local_fs $remote_fs $syslog
# Required-Stop: $remote_fs
# Should-Start: mysql postgresql rabbitmq-server keystone
# Should-Stop: mysql postgresql rabbitmq-server keystone
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Neutron Macvtap L2 agent
# Description: Provide Macvtap L2 agent for Neutron
### END INIT INFO
# Author: Corey Bryant <corey.bryant@canonical.com>
# PATH should only include /usr/* if it runs after the mountnfs.sh script
PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="OpenStack Neutron Macvtap L2 agent"
PROJECT_NAME=neutron
NAME=${PROJECT_NAME}-macvtap-agent
DAEMON={{ daemon_path }}
# --config-file=/etc/neutron/neutron.conf will be appended
# to DAEMON_ARGS later by openstack-pkg-tools
DAEMON_ARGS="--config-file=/etc/neutron/plugins/ml2/macvtap_agent.ini"

View File

@ -0,0 +1,24 @@
#!/bin/sh
### BEGIN INIT INFO
# Provides: neutron-metadata-agent
# Required-Start: $network $local_fs $remote_fs $syslog
# Required-Stop: $remote_fs
# Should-Start: mysql postgresql rabbitmq-server keystone openvswitch-switch
# Should-Stop: mysql postgresql rabbitmq-server keystone openvswitch-switch
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Neutron Metadata Agent agent
# Description: Provide Metadata agent for neutron
### END INIT INFO
# Author: Thomas Goirand <zigo@debian.org>
# PATH should only include /usr/* if it runs after the mountnfs.sh script
PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="OpenStack Neutron Metadata Agent"
PROJECT_NAME=neutron
NAME=${PROJECT_NAME}-metadata-agent
DAEMON={{ daemon_path }}
# --config-file=/etc/neutron/neutron.conf will be appended
# to DAEMON_ARGS later by openstack-pkg-tools
DAEMON_ARGS="--config-file=/etc/neutron/metadata_agent.ini"

View File

@ -0,0 +1,24 @@
#!/bin/sh
### BEGIN INIT INFO
# Provides: neutron-metering-agent
# Required-Start: $network $local_fs $remote_fs $syslog
# Required-Stop: $remote_fs
# Should-Start: mysql postgresql rabbitmq-server keystone openvswitch-switch
# Should-Stop: mysql postgresql rabbitmq-server keystone openvswitch-switch
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Neutron Metering Agent agent
# Description: Provides Metering agent for neutron
### END INIT INFO
# Author: Thomas Goirand <zigo@debian.org>
# PATH should only include /usr/* if it runs after the mountnfs.sh script
PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="OpenStack Neutron Metering Agent"
PROJECT_NAME=neutron
NAME=${PROJECT_NAME}-metering-agent
DAEMON={{ daemon_path }}
# --config-file=/etc/neutron/neutron.conf will be appended
# to DAEMON_ARGS later by openstack-pkg-tools
DAEMON_ARGS="--config-file=/etc/neutron/metering_agent.ini"

View File

@ -0,0 +1,20 @@
#!/bin/sh
### BEGIN INIT INFO
# Provides: neutron-openvswitch-agent
# Required-Start: $network $local_fs $remote_fs $syslog
# Required-Stop: $remote_fs openvswitch-switch
# Should-Start: mysql postgresql rabbitmq-server keystone neutron-ovs-cleanup
# Should-Stop: mysql postgresql rabbitmq-server keystone
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Neutron Open vSwitch Agent
# Description: Open vSwitch agent for OpenStack Neutron ML2 plugin
### END INIT INFO
# Authors: Julien Danjou <acid@debian.org>, Thomas Goirand <zigo@debian.org>
DESC="Openstack Neutron Open vSwitch Agent"
PROJECT_NAME=neutron
NAME=${PROJECT_NAME}-openvswitch-agent
DAEMON={{ daemon_path }}
DAEMON_ARGS="--config-file=/etc/neutron/plugins/ml2/openvswitch_agent.ini"

View File

@ -0,0 +1,19 @@
[Unit]
Description=Openstack Neutron Open vSwitch Plugin Agent
After=mysql.service postgresql.service rabbitmq-server.service keystone.service
Requires=neutron-ovs-cleanup.service
[Service]
User=neutron
Group=neutron
WorkingDirectory=/var/lib/neutron
PermissionsStartOnly=true
ExecStartPre=/bin/mkdir -p /var/lock/neutron /var/log/neutron /var/lib/neutron
ExecStartPre=/bin/chown neutron:neutron /var/lock/neutron /var/log/neutron /var/lib/neutron
ExecStart=/etc/init.d/neutron-openvswitch-agent systemd-start
Restart=on-failure
LimitNOFILE=65535
[Install]
WantedBy=multi-user.target

View File

@ -0,0 +1,19 @@
#!/bin/sh
### BEGIN INIT INFO
# Provides: neutron-ovs-cleanup
# Required-Start: $network $local_fs $remote_fs $syslog openvswitch-switch
# Required-Stop: $remote_fs
# Should-Start:
# Should-Stop:
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Neutron OVS Cleanup
# Description: OpenvSwitch Cleanup for OpenStack Neutron
### END INIT INFO
# Authors: James Page <james.page@ubuntu.com>
DESC="OpenStack Neutron OVS cleanup"
PROJECT_NAME=neutron
NAME=${PROJECT_NAME}-ovs-cleanup
DAEMON={{ daemon_path }}

View File

@ -0,0 +1,17 @@
[Unit]
Description=OpenStack Neutron OVS cleanup
[Service]
type=oneshot
User=neutron
Group=neutron
WorkingDirectory=/var/lib/neutron
PermissionsStartOnly=true
ExecStartPre=/bin/mkdir -p /var/lock/neutron /var/log/neutron /var/lib/neutron
ExecStartPre=/bin/chown neutron:neutron /var/lock/neutron /var/log/neutron /var/lib/neutron
ExecStart=/etc/init.d/neutron-ovs-cleanup systemd-start
RemainAfterExit=yes
[Install]
WantedBy=multi-user.target

View File

@ -0,0 +1,20 @@
#!/bin/sh
### BEGIN INIT INFO
# Provides: neutron-plugin-openvswitch-agent
# Required-Start: $network $local_fs $remote_fs $syslog
# Required-Stop: $remote_fs openvswitch-switch
# Should-Start: mysql postgresql rabbitmq-server keystone neutron-ovs-cleanup
# Should-Stop: mysql postgresql rabbitmq-server keystone
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Neutron Open vSwitch Agent
# Description: Open vSwitch agent for OpenStack Neutron ML2 plugin
### END INIT INFO
# Authors: Julien Danjou <acid@debian.org>, Thomas Goirand <zigo@debian.org>
DESC="Openstack Neutron Open vSwitch Agent"
PROJECT_NAME=neutron
NAME=${PROJECT_NAME}-plugin-openvswitch-agent
DAEMON={{ daemon_path }}
DAEMON_ARGS="--config-file=/etc/neutron/plugins/ml2/openvswitch_agent.ini"

View File

@ -0,0 +1,19 @@
[Unit]
Description=Openstack Neutron Open vSwitch Plugin Agent
After=mysql.service postgresql.service rabbitmq-server.service keystone.service
Requires=neutron-ovs-cleanup.service
[Service]
User=neutron
Group=neutron
WorkingDirectory=/var/lib/neutron
PermissionsStartOnly=true
ExecStartPre=/bin/mkdir -p /var/lock/neutron /var/log/neutron /var/lib/neutron
ExecStartPre=/bin/chown neutron:neutron /var/lock/neutron /var/log/neutron /var/lib/neutron
ExecStart=/etc/init.d/neutron-plugin-openvswitch-agent systemd-start
Restart=on-failure
LimitNOFILE=65535
[Install]
WantedBy=multi-user.target

View File

@ -0,0 +1,19 @@
#! /bin/sh
### BEGIN INIT INFO
# Provides: neutron-server
# Required-Start: $remote_fs $syslog
# Required-Stop: $remote_fs $syslog
# Should-Start: mysql postgresql rabbitmq-server keystone
# Should-Stop: mysql postgresql rabbitmq-server keystone
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: neutron-server
# Description: Provides the Neutron networking service
### END INIT INFO
DESC="OpenStack Neutron Server"
PROJECT_NAME=neutron
NAME=${PROJECT_NAME}-server
DAEMON={{ daemon_path }}
[ -r /etc/default/neutron-server ] && . /etc/default/neutron-server
[ -n "$NEUTRON_PLUGIN_CONFIG" ] && DAEMON_ARGS="--config-file=$NEUTRON_PLUGIN_CONFIG"

View File

@ -0,0 +1,22 @@
#!/bin/sh
### BEGIN INIT INFO
# Provides: neutron-sriov-agent
# Required-Start: $network $local_fs $remote_fs $syslog
# Required-Stop: $remote_fs
# Should-Start: mysql postgresql rabbitmq-server keystone
# Should-Stop: mysql postgresql rabbitmq-server keystone
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Neutron SRIOV Agent
# Description: SRIOV agent for OpenStack Neutron
### END INIT INFO
# Authors: James Page <james.page@ubuntu.com>
DESC="OpenStack Neutron SRIOV Plugin Agent"
PROJECT_NAME=neutron
NAME=${PROJECT_NAME}-sriov-agent
DAEMON={{ daemon_path }}
# --config-file=/etc/neutron/neutron.conf will be appended
# to DAEMON_ARGS later by openstack-pkg-tools
DAEMON_ARGS="--config-file=/etc/neutron/plugins/ml2/sriov_agent.ini"

View File

@ -0,0 +1,24 @@
#!/bin/sh
### BEGIN INIT INFO
# Provides: neutron-vpn-agent
# Required-Start: $network $local_fs $remote_fs $syslog
# Required-Stop: $remote_fs
# Should-Start: mysql postgresql rabbitmq-server keystone openvswitch-switch neutron-ovs-cleanup
# Should-Stop: mysql postgresql rabbitmq-server keystone openvswitch-switch
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Neutron VPN Agent agent
# Description: Provides VPN agent for neutron
### END INIT INFO
# Author: Thomas Goirand <zigo@debian.org>
# PATH should only include /usr/* if it runs after the mountnfs.sh script
PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="OpenStack Neutron VPN Agent"
PROJECT_NAME=neutron
NAME=${PROJECT_NAME}-vpn-agent
DAEMON={{ daemon_path }}
# --config-file=/etc/neutron/neutron.conf will be happened
# to DAEMON_ARGS later by openstack-pkg-tools
DAEMON_ARGS="--config-file=/etc/neutron/l3_agent.ini --config-file=/etc/neutron/fwaas_driver.ini --config-file=/etc/neutron/vpn_agent.ini"

View File

@ -0,0 +1,21 @@
#!/bin/sh
### BEGIN INIT INFO
# Provides: nova-api-metadata
# Required-Start: $network $local_fs $remote_fs $syslog
# Required-Stop: $remote_fs
# Should-Start: postgresql mysql keystone rabbitmq-server ntp
# Should-Stop: postgresql mysql keystone rabbitmq-server ntp
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Nova API metadata server
# Description: Frontend Nova API metadata server
### END INIT INFO
# Author: Julien Danjou <acid@debian.org>
# PATH should only include /usr/* if it runs after the mountnfs.sh script
PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="OpenStack Compute metadata API"
PROJECT_NAME=nova
NAME=${PROJECT_NAME}-api-metadata
DAEMON={{ daemon_path }}

View File

@ -0,0 +1,4 @@
Defaults:nova !requiretty
nova ALL = (root) NOPASSWD: /usr/local/bin/nova-rootwrap /etc/nova/rootwrap.conf *

View File

@ -20,16 +20,20 @@ TO_PATCH = [
'apt_upgrade', 'apt_upgrade',
'apt_install', 'apt_install',
'configure_installation_source', 'configure_installation_source',
'git_src_dir',
'log', 'log',
'add_bridge', 'add_bridge',
'add_bridge_port', 'add_bridge_port',
'headers_package', 'headers_package',
'full_restart', 'full_restart',
'os_release',
'service',
'service_running', 'service_running',
'NetworkServiceContext', 'NetworkServiceContext',
'ExternalPortContext', 'ExternalPortContext',
'unit_private_ip', 'unit_private_ip',
'relations_of_type', 'relations_of_type',
'render',
'service_stop', 'service_stop',
'determine_dkms_package', 'determine_dkms_package',
'service_restart', 'service_restart',
@ -793,18 +797,30 @@ class TestNeutronAgentReallocation(CharmTestCase):
core_project='neutron') core_project='neutron')
self.assertTrue(git_post.called) self.assertTrue(git_post.called)
@patch('subprocess.check_call')
@patch.object(neutron_utils, 'mkdir') @patch.object(neutron_utils, 'mkdir')
@patch.object(neutron_utils, 'write_file') @patch.object(neutron_utils, 'write_file')
@patch.object(neutron_utils, 'add_user_to_group') @patch.object(neutron_utils, 'add_user_to_group')
@patch.object(neutron_utils, 'add_group') @patch.object(neutron_utils, 'add_group')
@patch.object(neutron_utils, 'adduser') @patch.object(neutron_utils, 'adduser')
def test_git_pre_install(self, adduser, add_group, add_user_to_group, def test_git_pre_install(self, adduser, add_group, add_user_to_group,
write_file, mkdir): write_file, mkdir, check_call):
neutron_utils.git_pre_install() neutron_utils.git_pre_install()
adduser.assert_called_with('neutron', shell='/bin/bash', expected = [
system_user=True) call('neutron', shell='/bin/bash', system_user=True),
add_group.assert_called_with('neutron', system_group=True) call('nova', shell='/bin/bash', system_user=True),
add_user_to_group.assert_called_with('neutron', 'neutron') ]
self.assertEquals(adduser.call_args_list, expected)
expected = [
call('neutron', system_group=True),
call('nova', system_group=True),
]
self.assertEquals(add_group.call_args_list, expected)
expected = [
call('neutron', 'neutron'),
call('nova', 'nova'),
]
self.assertEquals(add_user_to_group.call_args_list, expected)
expected = [ expected = [
call('/etc/neutron', owner='neutron', call('/etc/neutron', owner='neutron',
group='neutron', perms=0755, force=False), group='neutron', perms=0755, force=False),
@ -820,6 +836,10 @@ class TestNeutronAgentReallocation(CharmTestCase):
group='neutron', perms=0755, force=False), group='neutron', perms=0755, force=False),
call('/var/log/neutron', owner='neutron', call('/var/log/neutron', owner='neutron',
group='neutron', perms=0755, force=False), group='neutron', perms=0755, force=False),
call('/var/lib/nova', owner='neutron',
group='neutron', perms=0755, force=False),
call('/var/log/nova', owner='neutron',
group='neutron', perms=0755, force=False),
] ]
self.assertEquals(mkdir.call_args_list, expected) self.assertEquals(mkdir.call_args_list, expected)
expected = [ expected = [
@ -863,18 +883,18 @@ class TestNeutronAgentReallocation(CharmTestCase):
self.assertEquals(write_file.call_args_list, expected) self.assertEquals(write_file.call_args_list, expected)
@patch('os.remove') @patch('os.remove')
@patch.object(neutron_utils, 'git_src_dir')
@patch.object(neutron_utils, 'render')
@patch('os.path.join') @patch('os.path.join')
@patch('os.path.exists') @patch('os.path.exists')
@patch('os.symlink') @patch('os.symlink')
@patch('shutil.rmtree') @patch('shutil.rmtree')
@patch('shutil.copyfile') @patch('shutil.copyfile')
@patch('shutil.copytree') @patch('shutil.copytree')
def test_git_post_install(self, copytree, copyfile, rmtree, symlink, def test_git_post_install_upstart(self, copytree, copyfile, rmtree,
exists, join, render, git_src_dir, remove): symlink, exists, join, remove):
projects_yaml = openstack_origin_git projects_yaml = openstack_origin_git
join.return_value = 'joined-string' join.return_value = 'joined-string'
self.lsb_release.return_value = {'DISTRIB_RELEASE': '15.04'}
self.os_release.return_value = 'liberty'
neutron_utils.git_post_install(projects_yaml) neutron_utils.git_post_install(projects_yaml)
expected = [ expected = [
call('joined-string', '/etc/neutron'), call('joined-string', '/etc/neutron'),
@ -1085,10 +1105,23 @@ class TestNeutronAgentReallocation(CharmTestCase):
'/etc/neutron/fwaas_driver.ini'], '/etc/neutron/fwaas_driver.ini'],
'log_file': '/var/log/neutron/vpn_agent.log', 'log_file': '/var/log/neutron/vpn_agent.log',
} }
nova_api_metadata_context = {
'service_description': 'Nova Metadata API server',
'service_name': 'nova-compute',
'user_name': 'nova',
'start_dir': '/var/lib/nova',
'process_name': 'nova-api-metadata',
'executable_name': 'joined-string',
'config_files': ['/etc/nova/nova.conf'],
}
expected = [ expected = [
call('git/neutron_sudoers', call('git/neutron_sudoers',
'/etc/sudoers.d/neutron_sudoers', '/etc/sudoers.d/neutron_sudoers',
{}, perms=0o440), {}, perms=0o440),
call('git/nova_sudoers',
'/etc/sudoers.d/nova_sudoers',
{}, perms=0o440),
call('git/cron.d/neutron-dhcp-agent-netns-cleanup', call('git/cron.d/neutron-dhcp-agent-netns-cleanup',
'/etc/cron.d/neutron-dhcp-agent-netns-cleanup', '/etc/cron.d/neutron-dhcp-agent-netns-cleanup',
{}, perms=0o755), {}, perms=0o755),
@ -1166,8 +1199,92 @@ class TestNeutronAgentReallocation(CharmTestCase):
call('git/upstart/neutron-agent.upstart', call('git/upstart/neutron-agent.upstart',
'/etc/init/neutron-vpn-agent.conf', '/etc/init/neutron-vpn-agent.conf',
neutron_vpn_agent_context, perms=0o644), neutron_vpn_agent_context, perms=0o644),
call('git.upstart',
'/etc/init/nova-api-metadata.conf',
nova_api_metadata_context, perms=0o644,
templates_dir='joined-string'),
] ]
self.assertEquals(render.call_args_list, expected) self.assertEquals(self.render.call_args_list, expected)
@patch('os.listdir')
@patch('os.remove')
@patch('os.path.join')
@patch('os.path.exists')
@patch('os.symlink')
@patch('shutil.rmtree')
@patch('shutil.copyfile')
@patch('shutil.copytree')
def test_git_post_install_systemd(self, copytree, copyfile, rmtree,
symlink, exists, join, remove, listdir):
projects_yaml = openstack_origin_git
join.return_value = 'joined-string'
self.lsb_release.return_value = {'DISTRIB_RELEASE': '15.10'}
self.os_release.return_value = 'xenial'
neutron_utils.git_post_install(projects_yaml)
expected = [
call('git/neutron_sudoers',
'/etc/sudoers.d/neutron_sudoers',
{}, perms=288),
call('git/nova_sudoers',
'/etc/sudoers.d/nova_sudoers',
{}, perms=288),
call('git/cron.d/neutron-dhcp-agent-netns-cleanup',
'/etc/cron.d/neutron-dhcp-agent-netns-cleanup',
{}, perms=493),
call('git/cron.d/neutron-l3-agent-netns-cleanup',
'/etc/cron.d/neutron-l3-agent-netns-cleanup',
{}, perms=493),
call('git/cron.d/neutron-lbaas-agent-netns-cleanup',
'/etc/cron.d/neutron-lbaas-agent-netns-cleanup',
{}, perms=493),
call('git/neutron-dhcp-agent.init.in.template',
'joined-string', {'daemon_path': 'joined-string'},
perms=420),
call('git/neutron-l3-agent.init.in.template',
'joined-string', {'daemon_path': 'joined-string'},
perms=420),
call('git/neutron-lbaas-agent.init.in.template',
'joined-string', {'daemon_path': 'joined-string'},
perms=420),
call('git/neutron-lbaasv2-agent.init.in.template',
'joined-string', {'daemon_path': 'joined-string'},
perms=420),
call('git/neutron-linuxbridge-agent.init.in.template',
'joined-string', {'daemon_path': 'joined-string'},
perms=420),
call('git/neutron-linuxbridge-cleanup.init.in.template',
'joined-string', {'daemon_path': 'joined-string'},
perms=420),
call('git/neutron-macvtap-agent.init.in.template',
'joined-string', {'daemon_path': 'joined-string'},
perms=420),
call('git/neutron-metadata-agent.init.in.template',
'joined-string', {'daemon_path': 'joined-string'},
perms=420),
call('git/neutron-metering-agent.init.in.template',
'joined-string', {'daemon_path': 'joined-string'},
perms=420),
call('git/neutron-openvswitch-agent.init.in.template',
'joined-string', {'daemon_path': 'joined-string'},
perms=420),
call('git/neutron-ovs-cleanup.init.in.template',
'joined-string', {'daemon_path': 'joined-string'},
perms=420),
call('git/neutron-server.init.in.template',
'joined-string', {'daemon_path': 'joined-string'},
perms=420),
call('git/neutron-sriov-agent.init.in.template',
'joined-string', {'daemon_path': 'joined-string'},
perms=420),
call('git/neutron-vpn-agent.init.in.template',
'joined-string', {'daemon_path': 'joined-string'},
perms=420),
call('git/nova-api-metadata.init.in.template',
'joined-string', {'daemon_path': 'joined-string'},
perms=420),
]
self.assertEquals(self.render.call_args_list, expected)
def test_assess_status(self): def test_assess_status(self):
with patch.object(neutron_utils, 'assess_status_func') as asf: with patch.object(neutron_utils, 'assess_status_func') as asf: