OpenStack Neutron Puppet Module
Go to file
Lars Kellogg-Stedman f9b3d184a0 Neutron Nova Interactions Support
Recent versions of Neutron are able to provide active notifications to
Nova about changes to port status and data.  This change adds the
neutron::server::notifications class to allow Puppet to configure this
feature when setting up a Neutron server.

neutron.conf requires a tenant UUID for communicating with Nova.  This
changes adds adds a custom type and provider to translate an admin
tenant name to the required UUID.

Co-Authored-By: emilienm <emilien.macchi@enovance.com>
Change-Id: I57af7cb47a12adabed9b1ee65e1c352b3e5fc2de
Closes-bug: 1306694
2014-04-22 09:57:21 -04:00
examples Neutron Nova Interactions Support 2014-04-22 09:57:21 -04:00
lib/puppet Neutron Nova Interactions Support 2014-04-22 09:57:21 -04:00
manifests Neutron Nova Interactions Support 2014-04-22 09:57:21 -04:00
spec Neutron Nova Interactions Support 2014-04-22 09:57:21 -04:00
.fixtures.yml Update remote url for puppet-vswitch 2013-11-21 16:36:07 +01:00
.gitignore Neutron Nova Interactions Support 2014-04-22 09:57:21 -04:00
.gitreview Renamed to neutron in the gitreview file 2013-08-17 22:03:19 -04:00
Gemfile Neutron Nova Interactions Support 2014-04-22 09:57:21 -04:00
LICENSE Licensed under Apache\! 2013-04-12 10:28:17 -07:00
Modulefile Updated to match semver and release notes. 2014-03-31 13:11:43 -07:00
README.md Updated to match semver and release notes. 2014-03-31 13:11:43 -07:00
Rakefile Fail puppet-lint on warnings 2013-08-28 19:59:48 -04:00

README.md

neutron

Table of Contents

  1. Overview - What is the neutron module?
  2. Module Description - What does the module do?
  3. Setup - Tha basics of getting started with neutron.
  4. Implementation - An under-the-hood peek at what the module is doing.
  5. Limitations - OS compatibility, etc.
  6. Development - Guide for contributing to the module
  7. Contributors - Those with commits
  8. Release Notes - Notes on the most recent updates to the module

Overview

The neutron module is a part of Stackforge, an effort by the Openstack infrastructure team to provide continuous integration testing and code review for Openstack and Openstack community projects not part of the core software. The module itself is used to flexibly configure and manage the newtork service for Openstack.

Module Description

The neutron module is an attempt to make Puppet capable of managing the entirety of neutron. This includes manifests to provision such things as keystone endpoints, RPC configurations specific to neutron, database connections, and network driver plugins. Types are shipped as part of the neutron module to assist in manipulation of the Openstack configuration files.

This module is tested in combination with other modules needed to build and leverage an entire Openstack installation. These modules can be found, all pulled together in the openstack module.

Setup

What the neutron module affects:

  • Neutron, the network service for Openstack.

Installing neutron

puppet module install puppetlabs/neutron

Beginning with neutron

To utilize the neutron module's functionality you will need to declare multiple resources. The following is a modified excerpt from the openstack module. It provides an example of setting up an Open vSwitch neutron installation. This is not an exhaustive list of all the components needed. We recommend that you consult and understand the openstack module and the core openstack documentation to assist you in understanding the available deployment options.

# enable the neutron service
class { '::neutron':
    enabled         => true,
    bind_host       => '127.0.0.1',
    rabbit_host     => '127.0.0.1',
    rabbit_user     => 'neutron',
    rabbit_password => 'rabbit_secret',
    verbose         => false,
    debug           => false,
}

# configure authentication
class { 'neutron::server':
    auth_host       => '127.0.0.1', # the keystone host address
    auth_password   => 'keystone_neutron_secret',
    sql_connection  => 'mysql://neutron:neutron_sql_secret@127.0.0.1/neutron?charset=utf8',
}

# enable the Open VSwitch plugin server
class { 'neutron::plugins::ovs':
    tenant_network_type => 'gre',
    network_vlan_ranges => 'physnet:1000:2000',
}

Other neutron network drivers include:

  • dhcp,
  • metadata,
  • and l3.

Nova will also need to be configured to connect to the neutron service. Setting up the nova::network::neutron class sets the network_api_class parameter in nova to use neutron instead of nova-network.

class { 'nova::network::neutron':
  neutron_admin_password  => 'neutron_admin_secret',
}

The examples directory also provides a quick tutorial on how to use this module.

Implementation

neutron

neutron is a combination of Puppet manifest and ruby code to deliver configuration and extra functionality through types and providers.

Limitations

This module supports the following neutron plugins:

  • Open vSwitch
  • linuxbridge
  • cisco-neutron

The following platforms are supported:

  • Ubuntu 12.04 (Precise)

  • Debian (Wheezy)

  • RHEL 6

  • Fedora 18

  • The Neutron Openstack service depends on a sqlalchemy database. If you are using puppetlabs-mysql to achieve this, there is a parameter called mysql_module that can be used to swap between the two supported versions: 0.9 and 2.2. This is needed because the puppetlabs-mysql module was rewritten and the custom type names have changed between versions. Development


The puppet-openstack modules follow the Openstack development model. Developer documentation for the entire puppet-openstack project is at:

Contributors

The github contributor graph.

Release Notes

3.2.0

  • Added write support for dns, allocation pools, and host routes to Neutron router provider.
  • Fixed multi-line attribute detection in base Neutron provider.
  • Fixed bugs with neutron router gateway id parsing.

3.1.0

  • Added VXLAN support.
  • Configures security group when using ML2 plugin.
  • Ensures installation of ML2 plugin.
  • Fixed server deprecated warnings.
  • Tuned report and downtime intervals for l2 agent.
  • Added support for neutron nvp plugin.
  • Ensures linuxbridge dependency is installed on RHEL.
  • Improved L3 scheduler support.
  • Fixed improper test for tunnel_types param.
  • Allows log_dir to be set to false in order to disable file logging.
  • Improves consistency with other puppet modules for OpenStack by prefixing database related parameters with database.
  • Removed strict checks for vlan_ranges.
  • Fixed neutron-metering-agent package for Ubuntu.
  • Fixed VPNaaS service name for Ubuntu.
  • Fixed FWaaS race condition.
  • Fixed ML2 package dependency for Ubuntu.
  • Removed erronious check for service_plugins.
  • Added support for https auth endpoints.
  • Makes haproxy package management optional.

3.0.0

  • Major release for OpenStack Havana.
  • Renamed project from quantum to neutron.
  • Changed the default quota_driver.
  • Removed provider setting requirement.
  • Fixed file permissions.
  • Fixed bug to ensure that keystone endpoint is set before service starts.
  • Added database configuration support for Havana.
  • Ensured dnsmasq package resource for compatibility with modules that define the same resource
  • Added multi-worker support.
  • Added metering agent support.
  • Added vpnaas agent support.
  • Added ml2 plugin support.
  • Fixed lbass driver name.

2.2.0

  • Improved documentation.
  • Added syslog support.
  • Added quantum-plugin-cisco package resource.
  • Various lint and bug fixes.