b24a176461
A previous patch added a link for further assistance during the DHCP agent installation section of the Neutron single-flat use-case. Unfortunately, the document it refers to is the one for the controller and not the network node as required. This patch updates the recently merged document to represent the correct page. The backport will also be rectified before merge. Change-Id: I4996804344bb29b10c7b07a8800ca2c1a6410b00
665 lines
40 KiB
XML
665 lines
40 KiB
XML
<?xml version="1.0" encoding="UTF-8"?>
|
|
<section xmlns="http://docbook.org/ns/docbook"
|
|
xmlns:xi="http://www.w3.org/2001/XInclude"
|
|
xmlns:xlink="http://www.w3.org/1999/xlink" version="5.0"
|
|
xml:id="section_neutron-single-flat">
|
|
<title>Single flat network</title>
|
|
<para>This section describes how to install the OpenStack
|
|
Networking service and its components for a single flat
|
|
network use case.</para>
|
|
<para>The following diagram shows the set up. For simplicity, all
|
|
nodes should have one interface for management traffic and one
|
|
or more interfaces for traffic to and from VMs. The management
|
|
network is 100.1.1.0/24 with controller node at 100.1.1.2. The example uses the Open vSwitch
|
|
plugin and agent.</para>
|
|
<note>
|
|
<para>You can modify this set up to make use of another
|
|
supported plug-in and its agent.</para>
|
|
</note>
|
|
<mediaobject>
|
|
<imageobject>
|
|
<imagedata scale="60"
|
|
fileref="../common/figures/demo_flat_install.png"/>
|
|
</imageobject>
|
|
</mediaobject>
|
|
<para>The following table describes some nodes in the set
|
|
up:</para>
|
|
<informaltable rules="all" width="100%">
|
|
<col width="20%"/>
|
|
<col width="80%"/>
|
|
<thead>
|
|
<tr>
|
|
<th>Node</th>
|
|
<th>Description</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
<tr>
|
|
<td>Controller Node</td>
|
|
<td><para>Runs the Networking service, Identity
|
|
Service, and Compute services that are
|
|
required to deploy VMs (<systemitem
|
|
class="service">nova-api</systemitem>,
|
|
<systemitem class="service"
|
|
>nova-scheduler</systemitem>, for
|
|
example). The node must have at least one
|
|
network interface, which is connected to the
|
|
Management Network. The host name is
|
|
<literal>controller</literal>, which every
|
|
other node resolves to the IP of the
|
|
controller node.</para>
|
|
<note>
|
|
<para>The <systemitem class="service">nova-network</systemitem> service
|
|
should not be running. This is replaced by the OpenStack Networking component,
|
|
<systemitem class="service">neutron</systemitem>.
|
|
To delete a network, run this command:</para>
|
|
<screen><prompt>#</prompt> <userinput>nova-manage network delete --help</userinput>
|
|
<computeroutput> Usage: nova-manage network delete <args> [options]
|
|
|
|
Options:
|
|
-h, --help show this help message and exit
|
|
--fixed_range=<x.x.x.x/yy>
|
|
Network to delete
|
|
--uuid=<uuid> UUID of network to delete</computeroutput></screen>
|
|
<para>Note that a network must first be disassociated from a project
|
|
using the <code>nova network-disassociate</code> command before it can be
|
|
deleted.</para>
|
|
</note></td>
|
|
</tr>
|
|
<tr>
|
|
<td>Compute Node</td>
|
|
<td>Runs the Networking L2 agent and the
|
|
Compute services that run VMs (<systemitem
|
|
class="service">nova-compute</systemitem>
|
|
specifically, and optionally other nova-* services
|
|
depending on configuration). The node must have at
|
|
least two network interfaces. The first
|
|
communicates with the controller node through the
|
|
management network. The second interface handles
|
|
the VM traffic on the data network. The VM can
|
|
receive its IP address from the DHCP agent on this
|
|
network.</td>
|
|
</tr>
|
|
<tr>
|
|
<td>Network Node</td>
|
|
<td>Runs Networking L2 agent and the DHCP agent. The
|
|
DHCP agent allocates IP addresses to the VMs on
|
|
the network. The node must have at least two
|
|
network interfaces. The first communicates with
|
|
the controller node through the management
|
|
network. The second interface handles the VM
|
|
traffic on the data network.</td>
|
|
</tr>
|
|
<tr>
|
|
<td>Router</td>
|
|
<td>Router has IP 30.0.0.1, which is the default
|
|
gateway for all VMs. The router must be able to
|
|
access public networks.</td>
|
|
</tr>
|
|
</tbody>
|
|
</informaltable>
|
|
<para>The demo assumes the following prerequisites:</para>
|
|
<para><emphasis role="bold">Controller node</emphasis></para>
|
|
<orderedlist>
|
|
<listitem>
|
|
<para>Relevant Compute services are installed, configured,
|
|
and running.</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Glance is installed, configured, and running.
|
|
Additionally, an image must be available.</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>OpenStack Identity is installed, configured, and
|
|
running. A Networking user <emphasis role="bold"
|
|
>neutron</emphasis> is in place on tenant
|
|
<emphasis role="bold">service</emphasis> with
|
|
password
|
|
<replaceable>NEUTRON_PASS</replaceable>.</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Additional services:</para>
|
|
<itemizedlist>
|
|
<listitem os="ubuntu;debian;opensuse;sles">
|
|
<para>RabbitMQ is running with the default guest user
|
|
and password.</para>
|
|
</listitem>
|
|
<listitem os="rhel;centos;fedora">
|
|
<para>Qpid is running with the default guest user
|
|
and password.</para>
|
|
</listitem>
|
|
<listitem os="rhel;centos;fedora;opensuse;sles;ubuntu">
|
|
<para>MySQL server (user is <emphasis role="bold"
|
|
>root</emphasis> and password is <emphasis
|
|
role="bold">root</emphasis>).</para>
|
|
</listitem>
|
|
</itemizedlist>
|
|
</listitem>
|
|
</orderedlist>
|
|
<para><emphasis role="bold">Compute node</emphasis></para>
|
|
<orderedlist>
|
|
<listitem>
|
|
<para>Compute is installed and configured.</para>
|
|
</listitem>
|
|
</orderedlist>
|
|
<section xml:id="demo_flat_installions">
|
|
<title>Install</title>
|
|
<itemizedlist>
|
|
<listitem>
|
|
<para><emphasis role="bold">Controller node -
|
|
Networking server</emphasis><orderedlist>
|
|
<listitem>
|
|
<para
|
|
os="rhel;centos;fedora;opensuse;sles;ubuntu"
|
|
>Install the Networking server.</para>
|
|
<para os="debian">Install the Networking
|
|
server and respond to <systemitem
|
|
class="library"
|
|
>debconf</systemitem> prompts to
|
|
configure the database, the
|
|
<code>keystone_authtoken</code>,
|
|
and the RabbitMQ credentials.</para>
|
|
<para>
|
|
See <xref linkend="install-neutron.dedicated-controller-node"/>
|
|
for installation instructions.</para>
|
|
</listitem>
|
|
<listitem
|
|
os="rhel;centos;fedora;opensuse;sles;ubuntu">
|
|
<para>Create database <emphasis
|
|
role="bold"
|
|
>ovs_neutron</emphasis>.</para>
|
|
<para>
|
|
See <xref linkend="neutron-install-network-node"/>
|
|
for database creation details.
|
|
</para>
|
|
</listitem>
|
|
<listitem os="rhel;centos;fedora;opensuse;sles">
|
|
<para>If not already configured, update the Networking <filename>
|
|
/etc/neutron/neutron.conf</filename>
|
|
configuration file to use the Identity Service, the plug-in,
|
|
and database configuration:</para>
|
|
<screen><prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf keystone_authtoken \
|
|
auth_port 35357</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf keystone_authtoken \
|
|
auth_protocol http</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf keystone_authtoken \
|
|
admin_tenant_name service</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf keystone_authtoken \
|
|
admin_user neutron</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf keystone_authtoken \
|
|
admin_password <replaceable>NEUTRON_PASS</replaceable></userinput></screen>
|
|
<para>Configure Networking to connect to the database:</para>
|
|
<screen><prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DATABASE sql_connection \
|
|
mysql://neutron:<replaceable>NEUTRON_DBPASS</replaceable>@controller/neutron</userinput></screen>
|
|
<para>Configure Networking to use your chosen plug-in:</para>
|
|
<screen><prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
core_plugin neutron.plugins.openvswitch.ovs_neutron_plugin.OVSNeutronPluginV2</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
control_exchange neutron</userinput></screen>
|
|
<para os="opensuse;sles">Configure access to the <application>RabbitMQ</application> service:</para>
|
|
<screen os="opensuse;sles"><prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
rpc_backend neutron.openstack.common.rpc.impl_kombu</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
rabbit_host controller</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
rabbit_userid guest</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
rabbit_password <replaceable>RABBIT_PASS</replaceable></userinput></screen>
|
|
<para os="rhel;centos;fedora">Configure access to the <application>Qpid</application> message queue:</para>
|
|
<screen os="rhel;centos;fedora"><prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
rpc_backend neutron.openstack.common.rpc.impl_qpid</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
qpid_hostname <replaceable>controller</replaceable></userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
qpid_port 5672</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
qpid_username <replaceable>guest</replaceable></userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
qpid_password <replaceable>guest</replaceable></userinput></screen>
|
|
</listitem>
|
|
<listitem os="ubuntu">
|
|
<para>If not already configured, update the Networking <filename>
|
|
/etc/neutron/neutron.conf</filename>
|
|
configuration file to choose a plug-in
|
|
and Identity Service user as
|
|
necessary:</para>
|
|
<programlisting language="ini">[DEFAULT]
|
|
core_plugin = neutron.plugins.openvswitch.ovs_neutron_plugin.OVSNeutronPluginV2
|
|
control_exchange = neutron
|
|
rabbit_host = <replaceable>controller</replaceable>
|
|
rabbit_password = <replaceable>RABBIT_PASS</replaceable>
|
|
notification_driver = neutron.openstack.common.notifier.rabbit_notifier
|
|
|
|
[database]
|
|
connection = mysql://neutron:<replaceable>NEUTRON_DBPASS</replaceable>@<replaceable>controller</replaceable>/neutron
|
|
|
|
[keystone_authtoken]
|
|
admin_tenant_name=service
|
|
admin_user=neutron
|
|
admin_password=<replaceable>NEUTRON_PASS</replaceable>
|
|
</programlisting>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Update the plug-in <filename>
|
|
/etc/neutron/plugins/openvswitch/ovs_neutron_plugin.ini</filename>
|
|
configuration file with the bridge mappings:</para>
|
|
<programlisting language="ini" os="ubuntu;debian">[ovs]
|
|
network_vlan_ranges = physnet1
|
|
bridge_mappings = physnet1:br-eth0
|
|
</programlisting>
|
|
<screen os="rhel;centos;fedora;opensuse;sles"><prompt>#</prompt> <userinput>openstack-config --set \
|
|
/etc/neutron/plugins/openvswitch/ovs_neutron_plugin.ini OVS \
|
|
network_vlan_ranges physnet1</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set \
|
|
/etc/neutron/plugins/openvswitch/ovs_neutron_plugin.ini OVS \
|
|
bridge_mappings physnet1:br-eth0</userinput></screen>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Restart the Networking service:</para>
|
|
<screen os="rhel;centos;fedora;ubuntu;debian"><prompt>#</prompt> <userinput>service neutron-server restart</userinput></screen>
|
|
<screen os="opensuse;sles"><prompt>#</prompt> <userinput>service openstack-neutron restart</userinput></screen>
|
|
</listitem>
|
|
</orderedlist></para>
|
|
</listitem>
|
|
<listitem>
|
|
<para><emphasis role="bold">Compute node - Compute </emphasis><orderedlist>
|
|
<listitem>
|
|
<para>Install the <systemitem
|
|
class="service"
|
|
>nova-compute</systemitem>
|
|
service.</para>
|
|
<para>
|
|
See <xref linkend="nova-compute"/>
|
|
for installation instructions.</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Update the Compute <filename>
|
|
/etc/nova/nova.conf</filename>
|
|
configuration file to make use
|
|
of OpenStack Networking:</para>
|
|
<programlisting language="ini" os="ubuntu;debian">network_api_class=nova.network.neutronv2.api.API
|
|
|
|
neutron_admin_username=neutron
|
|
neutron_admin_password=<replaceable>NEUTRON_PASS</replaceable>
|
|
neutron_admin_auth_url=http://<replaceable>controller</replaceable>:35357/v2.0/
|
|
neutron_auth_strategy=keystone
|
|
neutron_admin_tenant_name=service
|
|
neutron_url=http://<replaceable>controller</replaceable>:9696/</programlisting>
|
|
<screen os="rhel;centos;fedora;opensuse;sles"><prompt>#</prompt> <userinput>openstack-config --set /etc/nova/nova.conf DEFAULT \
|
|
network_api_class nova.network.neutronv2.api.API</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/nova/nova.conf DEFAULT \
|
|
neutron_url http://<replaceable>controller</replaceable>:9696</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/nova/nova.conf DEFAULT \
|
|
neutron_auth_strategy keystone</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/nova/nova.conf DEFAULT \
|
|
neutron_admin_tenant_name service</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/nova/nova.conf DEFAULT \
|
|
neutron_admin_username neutron</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/nova/nova.conf DEFAULT \
|
|
neutron_admin_password <replaceable>NEUTRON_PASS</replaceable></userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/nova/nova.conf DEFAULT \
|
|
neutron_admin_auth_url http://<replaceable>controller</replaceable>:35357/v2.0</userinput></screen>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Restart the Compute services</para>
|
|
<screen os="rhel;centos;fedora;opensuse;sles"><prompt>#</prompt> <userinput>service openstack-nova-compute restart</userinput></screen>
|
|
<screen os="ubuntu;debian"><prompt>#</prompt> <userinput>service nova-compute restart</userinput></screen>
|
|
</listitem>
|
|
</orderedlist></para>
|
|
</listitem>
|
|
<listitem>
|
|
<para><emphasis role="bold">Compute and Network
|
|
node - L2 agent</emphasis><orderedlist>
|
|
<listitem>
|
|
<para>Install and start Open vSwitch.
|
|
Then, configure <systemitem class="service">neutron</systemitem> accordingly.</para>
|
|
<para>
|
|
See <xref linkend="install-neutron.install-plug-in"/>
|
|
for detailed instructions.</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Add the integration bridge to Open
|
|
vSwitch:</para>
|
|
<screen><prompt>#</prompt> <userinput>ovs-vsctl add-br br-int</userinput></screen>
|
|
</listitem>
|
|
<listitem os="ubuntu;debian">
|
|
<para>Update the Networking <filename>
|
|
/etc/neutron/neutron.conf</filename>
|
|
configuration file:</para>
|
|
<programlisting language="ini">[DEFAULT]
|
|
core_plugin = neutron.plugins.openvswitch.ovs_neutron_plugin.OVSNeutronPluginV2
|
|
control_exchange = neutron
|
|
rabbit_host = <replaceable>controller</replaceable>
|
|
rabbit_password = <replaceable>RABBIT_PASS</replaceable>
|
|
notification_driver = neutron.openstack.common.notifier.rabbit_notifier
|
|
|
|
[database]
|
|
connection = mysql://neutron:<replaceable>NEUTRON_DBPASS</replaceable>@<replaceable>controller</replaceable>/neutron
|
|
</programlisting>
|
|
</listitem>
|
|
<listitem os="rhel;centos;fedora;opensuse;sles">
|
|
<para>If not already configured, update the Networking <filename>
|
|
/etc/neutron/neutron.conf</filename>
|
|
configuration file to use the plug-in, message queue,
|
|
and database configuration:</para>
|
|
<screen><prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DATABASE sql_connection \
|
|
mysql://neutron:<replaceable>NEUTRON_DBPASS</replaceable>@controller/neutron</userinput></screen>
|
|
<para>Configure Networking to use your chosen plug-in:</para>
|
|
<screen><prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
core_plugin neutron.plugins.openvswitch.ovs_neutron_plugin.OVSNeutronPluginV2</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
control_exchange neutron</userinput></screen>
|
|
<para os="opensuse;sles">Configure access to the <application>RabbitMQ</application> service:</para>
|
|
<screen os="opensuse;sles"><prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
rpc_backend neutron.openstack.common.rpc.impl_kombu</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
rabbit_host controller</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
rabbit_userid guest</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
rabbit_password <replaceable>RABBIT_PASS</replaceable></userinput></screen>
|
|
<para os="rhel;centos;fedora">Configure access to the <application>Qpid</application> message queue:</para>
|
|
<screen os="rhel;centos;fedora"><prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
rpc_backend neutron.openstack.common.rpc.impl_qpid</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
qpid_hostname <replaceable>controller</replaceable></userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
qpid_port 5672</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
qpid_username <replaceable>guest</replaceable></userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
qpid_password <replaceable>guest</replaceable></userinput></screen>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Update the plug-in <filename>
|
|
/etc/neutron/plugins/openvswitch/ovs_neutron_plugin.ini</filename>
|
|
configuration file:</para>
|
|
<programlisting language="ini" os="ubuntu;debian">[ovs]
|
|
network_vlan_ranges = physnet1
|
|
bridge_mappings = physnet1:br-eth0</programlisting>
|
|
<screen os="rhel;centos;fedora;opensuse;sles"><prompt>#</prompt> <userinput>openstack-config --set \
|
|
/etc/neutron/plugins/openvswitch/ovs_neutron_plugin.ini OVS \
|
|
network_vlan_ranges physnet1</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set \
|
|
/etc/neutron/plugins/openvswitch/ovs_neutron_plugin.ini OVS \
|
|
bridge_mappings physnet1:br-eth0</userinput></screen>
|
|
</listitem>
|
|
<listitem os="centos">
|
|
<para>Create a symbolic link from <filename>/etc/neutron/plugin.ini</filename> to <filename>/etc/neutron/plugins/openvswitch/ovs_neutron_plugin.ini</filename> or <code>neutron-server</code> will not run:
|
|
</para>
|
|
<screen><prompt>#</prompt> <userinput>ln -s /etc/neutron/plugins/openvswitch/ovs_neutron_plugin.ini /etc/neutron/plugin.ini</userinput></screen>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Create the <emphasis role="bold"
|
|
>br-eth0</emphasis> network bridge
|
|
to handle communication between nodes
|
|
using eth0:</para>
|
|
<screen><prompt>#</prompt> <userinput>ovs-vsctl add-br br-eth0</userinput>
|
|
<prompt>#</prompt> <userinput>ovs-vsctl add-port br-eth0 eth0</userinput></screen>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Restart the OpenStack Networking L2
|
|
agent:</para>
|
|
<screen os="opensuse;sles"><prompt>#</prompt> <userinput>service openstack-neutron-openvswitch-agent restart</userinput></screen>
|
|
<screen os="rhel;centos;fedora;ubuntu;debian"><prompt>#</prompt> <userinput>service neutron-openvswitch-agent restart</userinput></screen>
|
|
</listitem>
|
|
</orderedlist></para>
|
|
</listitem>
|
|
<listitem>
|
|
<para><emphasis role="bold">Network node - DHCP
|
|
agent</emphasis><orderedlist>
|
|
<listitem>
|
|
<para>Install the DHCP agent.</para>
|
|
<para>
|
|
See <xref linkend="neutron-install.dedicated-network-node"/>
|
|
for <emphasis role="bold">generic</emphasis> installation instructions.</para>
|
|
</listitem>
|
|
<listitem os="ubuntu;debian">
|
|
<para>Update the Networking <filename>
|
|
/etc/neutron/neutron.conf</filename>
|
|
configuration file:</para>
|
|
<programlisting language="ini">[DEFAULT]
|
|
core_plugin = neutron.plugins.openvswitch.ovs_neutron_plugin.OVSNeutronPluginV2
|
|
control_exchange = neutron
|
|
rabbit_host = <replaceable>controller</replaceable>
|
|
rabbit_password = <replaceable>RABBIT_PASS</replaceable>
|
|
notification_driver = neutron.openstack.common.notifier.rabbit_notifier</programlisting>
|
|
</listitem>
|
|
<listitem os="rhel;centos;fedora;opensuse;sles">
|
|
<para>If not already configured, update the Networking <filename>
|
|
/etc/neutron/neutron.conf</filename>
|
|
configuration file to use the plug-in and message queue.</para>
|
|
<screen><prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
core_plugin neutron.plugins.openvswitch.ovs_neutron_plugin.OVSNeutronPluginV2</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
control_exchange neutron</userinput></screen>
|
|
<para os="opensuse;sles">Configure access to the <application>RabbitMQ</application> service:</para>
|
|
<screen os="opensuse;sles"><prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
rpc_backend neutron.openstack.common.rpc.impl_kombu</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
rabbit_host controller</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
rabbit_userid guest</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
rabbit_password <replaceable>RABBIT_PASS</replaceable></userinput></screen>
|
|
<para os="rhel;centos;fedora">Configure access to the <application>Qpid</application> message queue:</para>
|
|
<screen os="rhel;centos;fedora"><prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
rpc_backend neutron.openstack.common.rpc.impl_qpid</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
qpid_hostname <replaceable>controller</replaceable></userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
qpid_port 5672</userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
qpid_username <replaceable>guest</replaceable></userinput>
|
|
<prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/neutron.conf DEFAULT \
|
|
qpid_password <replaceable>guest</replaceable></userinput></screen>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Ensure that the DHCP agent is using the correct
|
|
plug-in my changing the configuration in <filename>
|
|
/etc/neutron/dhcp_agent.ini</filename>:</para>
|
|
<programlisting language="ini" os="ubuntu;debian">interface_driver = neutron.agent.linux.interface.OVSInterfaceDriver</programlisting>
|
|
<screen os="rhel;centos;fedora;opensuse;sles"><prompt>#</prompt> <userinput>openstack-config --set /etc/neutron/dhcp_agent.ini DEFAULT \
|
|
interface_driver neutron.agent.linux.interface.OVSInterfaceDriver</userinput></screen>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Restart the DHCP agent:</para>
|
|
<screen os="opensuse;sles"><prompt>#</prompt> <userinput>service openstack-neutron-dhcp-agent restart</userinput></screen>
|
|
<screen os="rhel;centos;fedora;ubuntu;debian"><prompt>#</prompt> <userinput>service neutron-dhcp-agent restart</userinput></screen>
|
|
</listitem>
|
|
</orderedlist></para>
|
|
</listitem>
|
|
</itemizedlist>
|
|
</section>
|
|
<section xml:id="demo_flat_logical_network_config">
|
|
<title>Configure logical network</title>
|
|
<para>Use the following commands on the network node.</para>
|
|
<note>
|
|
<para>Ensure that the following environment variables are
|
|
set. Various clients use these variables to access the
|
|
Identity Service.</para>
|
|
</note>
|
|
<programlisting language="bash">export OS_USERNAME=admin
|
|
export OS_PASSWORD=<replaceable>ADMIN_PASS</replaceable>
|
|
export OS_TENANT_NAME=admin
|
|
export OS_AUTH_URL=http://<replaceable>controller</replaceable>:5000/v2.0/</programlisting>
|
|
<orderedlist>
|
|
<listitem>
|
|
<para>Get the tenant ID (Used as $TENANT_ID
|
|
later):</para>
|
|
<screen><prompt>#</prompt> <userinput>keystone tenant-list</userinput>
|
|
<computeroutput>+----------------------------------+---------+---------+
|
|
| id | name | enabled |
|
|
+----------------------------------+---------+---------+
|
|
| 247e478c599f45b5bd297e8ddbbc9b6a | TenantA | True |
|
|
| 2b4fec24e62e4ff28a8445ad83150f9d | TenantC | True |
|
|
| 3719a4940bf24b5a8124b58c9b0a6ee6 | TenantB | True |
|
|
| 5fcfbc3283a142a5bb6978b549a511ac | demo | True |
|
|
| b7445f221cda4f4a8ac7db6b218b1339 | admin | True |
|
|
+----------------------------------+---------+---------+</computeroutput></screen>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Get the user information:</para>
|
|
<screen><prompt>#</prompt> <userinput>keystone user-list</userinput>
|
|
<computeroutput>+----------------------------------+-------+---------+-------------------+
|
|
| id | name | enabled | email |
|
|
+----------------------------------+-------+---------+-------------------+
|
|
| 5a9149ed991744fa85f71e4aa92eb7ec | demo | True | |
|
|
| 5b419c74980d46a1ab184e7571a8154e | admin | True | admin@example.com |
|
|
| 8e37cb8193cb4873a35802d257348431 | UserC | True | |
|
|
| c11f6b09ed3c45c09c21cbbc23e93066 | UserB | True | |
|
|
| ca567c4f6c0942bdac0e011e97bddbe3 | UserA | True | |
|
|
+----------------------------------+-------+---------+-------------------+</computeroutput></screen>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Create a internal shared network on the demo
|
|
tenant ($TENANT_ID is
|
|
b7445f221cda4f4a8ac7db6b218b1339):</para>
|
|
<screen><prompt>$</prompt> <userinput>neutron net-create --tenant-id $TENANT_ID sharednet1 --shared --provider:network_type flat \
|
|
--provider:physical_network physnet1</userinput>
|
|
<computeroutput>Created a new network:
|
|
+---------------------------+--------------------------------------+
|
|
| Field | Value |
|
|
+---------------------------+--------------------------------------+
|
|
| admin_state_up | True |
|
|
| id | 04457b44-e22a-4a5c-be54-a53a9b2818e7 |
|
|
| name | sharednet1 |
|
|
| provider:network_type | flat |
|
|
| provider:physical_network | physnet1 |
|
|
| provider:segmentation_id | |
|
|
| router:external | False |
|
|
| shared | True |
|
|
| status | ACTIVE |
|
|
| subnets | |
|
|
| tenant_id | b7445f221cda4f4a8ac7db6b218b1339 |
|
|
+---------------------------+--------------------------------------+</computeroutput></screen>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Create a subnet on the network:</para>
|
|
<screen><prompt>#</prompt> <userinput>neutron subnet-create --tenant-id $TENANT_ID sharednet1 30.0.0.0/24</userinput>
|
|
<computeroutput>Created a new subnet:
|
|
+------------------+--------------------------------------------+
|
|
| Field | Value |
|
|
+------------------+--------------------------------------------+
|
|
| allocation_pools | {"start": "30.0.0.2", "end": "30.0.0.254"} |
|
|
| cidr | 30.0.0.0/24 |
|
|
| dns_nameservers | |
|
|
| enable_dhcp | True |
|
|
| gateway_ip | 30.0.0.1 |
|
|
| host_routes | |
|
|
| id | b8e9a88e-ded0-4e57-9474-e25fa87c5937 |
|
|
| ip_version | 4 |
|
|
| name | |
|
|
| network_id | 04457b44-e22a-4a5c-be54-a53a9b2818e7 |
|
|
| tenant_id | 5fcfbc3283a142a5bb6978b549a511ac |
|
|
+------------------+--------------------------------------------+</computeroutput></screen>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Create a server for tenant A:</para>
|
|
<screen><prompt>#</prompt> <userinput>nova --os-tenant-name TenantA --os-username UserA --os-password password \
|
|
--os-auth-url=http://localhost:5000/v2.0 boot --image tty --flavor 1 \
|
|
--nic net-id=04457b44-e22a-4a5c-be54-a53a9b2818e7 TenantA_VM1</userinput></screen>
|
|
<screen><prompt>#</prompt> <userinput>nova --os-tenant-name TenantA --os-username UserA --os-password password \
|
|
--os-auth-url=http://localhost:5000/v2.0 list</userinput>
|
|
<computeroutput>+--------------------------------------+-------------+--------+---------------------+
|
|
| ID | Name | Status | Networks |
|
|
+--------------------------------------+-------------+--------+---------------------+
|
|
| 09923b39-050d-4400-99c7-e4b021cdc7c4 | TenantA_VM1 | ACTIVE | sharednet1=30.0.0.3 |
|
|
+--------------------------------------+-------------+--------+---------------------+</computeroutput></screen>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Ping the server of tenant A:</para>
|
|
<screen><prompt>#</prompt> <userinput>ip addr flush eth0</userinput>
|
|
<prompt>#</prompt> <userinput>ip addr add 30.0.0.201/24 dev br-eth0</userinput>
|
|
<prompt>$</prompt> <userinput>ping 30.0.0.3</userinput></screen>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Ping the public network within the server of
|
|
tenant A:</para>
|
|
<screen><prompt>#</prompt> <userinput>ping 192.168.1.1</userinput>
|
|
<computeroutput>PING 192.168.1.1 (192.168.1.1) 56(84) bytes of data.
|
|
64 bytes from 192.168.1.1: icmp_req=1 ttl=64 time=1.74 ms
|
|
64 bytes from 192.168.1.1: icmp_req=2 ttl=64 time=1.50 ms
|
|
64 bytes from 192.168.1.1: icmp_req=3 ttl=64 time=1.23 ms
|
|
^C
|
|
--- 192.168.1.1 ping statistics ---
|
|
3 packets transmitted, 3 received, 0% packet loss, time 2003ms
|
|
rtt min/avg/max/mdev = 1.234/1.495/1.745/0.211 ms</computeroutput></screen>
|
|
<note>
|
|
<para>The 192.168.1.1 is an IP on public network
|
|
to which the router connects.</para>
|
|
</note>
|
|
</listitem>
|
|
<listitem>
|
|
<para>Create servers for other tenants with similar
|
|
commands. Because all VMs share the same subnet,
|
|
they can access each other.</para>
|
|
</listitem>
|
|
</orderedlist>
|
|
</section>
|
|
<section xml:id="section_use-cases-single-flat">
|
|
<title>Use case: single flat network</title>
|
|
<para>The simplest use case is a single network. This is a
|
|
"shared" network, meaning it is visible to all tenants via
|
|
the Networking API. Tenant VMs have a single NIC, and
|
|
receive a fixed IP address from the subnet(s) associated
|
|
with that network. This use case essentially maps to the
|
|
FlatManager and FlatDHCPManager models provided by
|
|
Compute. Floating IPs are not supported.</para>
|
|
<para>This network type is often created by the OpenStack
|
|
administrator to map directly to an existing physical
|
|
network in the data center (called a "provider network").
|
|
This allows the provider to use a physical router on that
|
|
data center network as the gateway for VMs to reach the
|
|
outside world. For each subnet on an external network, the
|
|
gateway configuration on the physical router must be
|
|
manually configured outside of OpenStack.</para>
|
|
<mediaobject>
|
|
<imageobject>
|
|
<imagedata scale="80"
|
|
fileref="../common/figures/UseCase-SingleFlat.png"
|
|
/>
|
|
</imageobject>
|
|
</mediaobject>
|
|
<!--Image source link: https://docs.google.com/a/nicira.com/drawings/d/1Jb6iSoBo4G7fv7i2EMpYTMTxesLPmEPKIbI7sVbhhqY/edit -->
|
|
</section>
|
|
<?hard-pagebreak?>
|
|
<section xml:id="section_use-cases-multi-flat">
|
|
<title>Use case: multiple flat network</title>
|
|
<para>This use case is similar to the above single flat
|
|
network use case, except that tenants can see multiple
|
|
shared networks via the Networking API and can choose
|
|
which network (or networks) to plug into.</para>
|
|
<mediaobject>
|
|
<imageobject>
|
|
<imagedata scale="60"
|
|
fileref="../common/figures/UseCase-MultiFlat.png"
|
|
/>
|
|
</imageobject>
|
|
</mediaobject>
|
|
<!--Image source link: https://docs.google.com/a/nicira.com/drawings/d/14ayGsyunW_P-wvY8OiueE407f7540JD3VsWUH18KHvU/edit -->
|
|
</section>
|
|
<section xml:id="section_use-cases-mixed">
|
|
<title>Use case: mixed flat and private network</title>
|
|
<para>This use case is an extension of the above Flat Network
|
|
use cases. In addition to being able to see one or more
|
|
shared networks via the OpenStack Networking API, tenants
|
|
can also have access to private per-tenant networks (only
|
|
visible to tenant users).</para>
|
|
<para>Created VMs can have NICs on any of the shared or
|
|
private networks that the tenant owns. This enables the
|
|
creation of multi-tier topologies that use VMs with
|
|
multiple NICs. It also enables a VM to act as a gateway so
|
|
that it can provide services such as routing, NAT, and
|
|
load balancing.</para>
|
|
<mediaobject>
|
|
<imageobject>
|
|
<imagedata scale="55"
|
|
fileref="../common/figures/UseCase-MixedFlatPrivate.png"
|
|
/>
|
|
</imageobject>
|
|
</mediaobject>
|
|
<!--Image source link: https://docs.google.com/a/nicira.com/drawings/d/1efSqR6KA2gv-OKl5Rl-oV_zwgYP8mgQHFP2DsBj5Fqo/edit -->
|
|
</section>
|
|
</section>
|