blob: e3b2c4dd285aea5554e1343ce6833672e329f63a [file] [log] [blame]
Sean Daguee263c822014-12-05 14:25:28 -05001#!/bin/bash
2#
Mark McClainb05c8762013-07-06 23:29:39 -04003# Neutron Modular Layer 2 plugin
Bob Kukurac9b0f1a2013-04-23 16:28:24 -04004# ------------------------------
5
6# Save trace setting
Dean Troyere3a91602014-03-28 12:40:56 -05007ML2_XTRACE=$(set +o | grep xtrace)
Bob Kukurac9b0f1a2013-04-23 16:28:24 -04008set +o xtrace
9
Kyle Mesteryb7726592013-07-19 14:26:53 +000010# Enable this to simply and quickly enable tunneling with ML2.
Akihiro Motoki2307f9d2014-08-09 18:58:20 +090011# Select either 'gre', 'vxlan', or 'gre,vxlan'
Attila Fazekas8feaf6c2014-07-27 20:47:04 +020012Q_ML2_TENANT_NETWORK_TYPE=${Q_ML2_TENANT_NETWORK_TYPE:-"vxlan"}
Kyle Mesteryb7726592013-07-19 14:26:53 +000013# This has to be set here since the agent will set this in the config file
Kevin Bentone3cfbf12014-08-04 11:25:20 -060014if [[ "$Q_ML2_TENANT_NETWORK_TYPE" == "gre" || "$Q_ML2_TENANT_NETWORK_TYPE" == "vxlan" ]]; then
Akihiro Motoki2307f9d2014-08-09 18:58:20 +090015 Q_TUNNEL_TYPES=$Q_ML2_TENANT_NETWORK_TYPE
Kyle Mesterybd085502014-04-30 23:50:29 +000016elif [[ "$ENABLE_TENANT_TUNNELS" == "True" ]]; then
Akihiro Motoki2307f9d2014-08-09 18:58:20 +090017 Q_TUNNEL_TYPES=gre
Kyle Mesteryb7726592013-07-19 14:26:53 +000018fi
19
Bob Kukurac9b0f1a2013-04-23 16:28:24 -040020# Default openvswitch L2 agent
21Q_AGENT=${Q_AGENT:-openvswitch}
Mark McClainb05c8762013-07-06 23:29:39 -040022source $TOP_DIR/lib/neutron_plugins/${Q_AGENT}_agent
Bob Kukurac9b0f1a2013-04-23 16:28:24 -040023
Kyle Mesteryb7726592013-07-19 14:26:53 +000024# List of MechanismDrivers to load
Kyle Mesterybc632472013-09-06 14:59:30 +000025Q_ML2_PLUGIN_MECHANISM_DRIVERS=${Q_ML2_PLUGIN_MECHANISM_DRIVERS:-openvswitch,linuxbridge}
Kyle Mesteryb7726592013-07-19 14:26:53 +000026# List of Type Drivers to load
27Q_ML2_PLUGIN_TYPE_DRIVERS=${Q_ML2_PLUGIN_TYPE_DRIVERS:-local,flat,vlan,gre,vxlan}
28# Default GRE TypeDriver options
29Q_ML2_PLUGIN_GRE_TYPE_OPTIONS=${Q_ML2_PLUGIN_GRE_TYPE_OPTIONS:-tunnel_id_ranges=$TENANT_TUNNEL_RANGES}
30# Default VXLAN TypeDriver options
31Q_ML2_PLUGIN_VXLAN_TYPE_OPTIONS=${Q_ML2_PLUGIN_VXLAN_TYPE_OPTIONS:-vni_ranges=1001:2000}
32# Default VLAN TypeDriver options
33Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS=${Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS:-}
34
Kyle Mestery14ea1a22013-09-22 03:04:56 +000035# L3 Plugin to load for ML2
36ML2_L3_PLUGIN=${ML2_L3_PLUGIN:-neutron.services.l3_router.l3_router_plugin.L3RouterPlugin}
37
Ian Wienandaee18c72014-02-21 15:35:08 +110038function populate_ml2_config {
Akihiro Motoki130c90e2013-11-28 16:56:51 +090039 CONF=$1
40 SECTION=$2
41 OPTS=$3
Kyle Mesteryb7726592013-07-19 14:26:53 +000042
Akihiro Motoki130c90e2013-11-28 16:56:51 +090043 if [ -z "$OPTS" ]; then
44 return
45 fi
Kyle Mesteryb7726592013-07-19 14:26:53 +000046 for I in "${OPTS[@]}"; do
47 # Replace the first '=' with ' ' for iniset syntax
48 iniset $CONF $SECTION ${I/=/ }
49 done
50}
51
Ian Wienandaee18c72014-02-21 15:35:08 +110052function neutron_plugin_configure_common {
Mark McClainb05c8762013-07-06 23:29:39 -040053 Q_PLUGIN_CONF_PATH=etc/neutron/plugins/ml2
Bob Kukurac9b0f1a2013-04-23 16:28:24 -040054 Q_PLUGIN_CONF_FILENAME=ml2_conf.ini
Mark McClainb05c8762013-07-06 23:29:39 -040055 Q_PLUGIN_CLASS="neutron.plugins.ml2.plugin.Ml2Plugin"
Bob Melander748fe3d2013-01-31 17:12:56 +010056 # The ML2 plugin delegates L3 routing/NAT functionality to
57 # the L3 service plugin which must therefore be specified.
Isaku Yamahata9e136b42013-12-16 15:52:03 +090058 _neutron_service_plugin_class_add $ML2_L3_PLUGIN
Bob Kukurac9b0f1a2013-04-23 16:28:24 -040059}
60
Ian Wienandaee18c72014-02-21 15:35:08 +110061function neutron_plugin_configure_service {
Attila Fazekas8feaf6c2014-07-27 20:47:04 +020062 if [[ "$Q_ML2_TENANT_NETWORK_TYPE" != "local" ]]; then
Kyle Mestery061d5252013-09-09 08:52:19 +000063 Q_SRV_EXTRA_OPTS+=(tenant_network_types=$Q_ML2_TENANT_NETWORK_TYPE)
Kyle Mesterybd085502014-04-30 23:50:29 +000064 elif [[ "$ENABLE_TENANT_TUNNELS" == "True" ]]; then
Kyle Mesteryb7726592013-07-19 14:26:53 +000065 # This assumes you want a simple configuration, and will overwrite
66 # Q_SRV_EXTRA_OPTS if set in addition to ENABLE_TENANT_TUNNELS.
Kyle Mestery061d5252013-09-09 08:52:19 +000067 Q_SRV_EXTRA_OPTS+=(tenant_network_types=gre)
Kyle Mesteryb7726592013-07-19 14:26:53 +000068 Q_ML2_PLUGIN_GRE_TYPE_OPTIONS=(tunnel_id_ranges=$TENANT_TUNNEL_RANGES)
Kyle Mesterybd085502014-04-30 23:50:29 +000069 elif [[ "$ENABLE_TENANT_VLANS" == "True" ]]; then
Kyle Mestery061d5252013-09-09 08:52:19 +000070 Q_SRV_EXTRA_OPTS+=(tenant_network_types=vlan)
Bob Kukurac9b0f1a2013-04-23 16:28:24 -040071 else
72 echo "WARNING - The ml2 plugin is using local tenant networks, with no connectivity between hosts."
73 fi
74
Kyle Mesteryb7726592013-07-19 14:26:53 +000075 # Allow for overrding VLAN configuration (for example, to configure provider
76 # VLANs) by first checking if Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS is set.
77 if [ "$Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS" == "" ]; then
Kyle Mesterybd085502014-04-30 23:50:29 +000078 if [[ "$ML2_VLAN_RANGES" == "" ]] && [[ "$PHYSICAL_NETWORK" != "" ]]; then
Kyle Mesteryb7726592013-07-19 14:26:53 +000079 ML2_VLAN_RANGES=$PHYSICAL_NETWORK
80 if [[ "$TENANT_VLAN_RANGE" != "" ]]; then
81 ML2_VLAN_RANGES=$ML2_VLAN_RANGES:$TENANT_VLAN_RANGE
82 fi
Bob Kukurac9b0f1a2013-04-23 16:28:24 -040083 fi
Kyle Mesteryb7726592013-07-19 14:26:53 +000084 if [[ "$ML2_VLAN_RANGES" != "" ]]; then
85 Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS=(network_vlan_ranges=$ML2_VLAN_RANGES)
86 fi
Bob Kukurac9b0f1a2013-04-23 16:28:24 -040087 fi
88
yunhong jiang73d32162014-10-06 09:34:35 -070089
90 # Allow for setup the flat type network
91 if [[ -z "$Q_ML2_PLUGIN_FLAT_TYPE_OPTIONS" && -n "$PHYSICAL_NETWORK" ]]; then
92 Q_ML2_PLUGIN_FLAT_TYPE_OPTIONS="flat_networks=$Q_ML2_FLAT_PHYSNET_OPTIONS"
93 fi
Bob Kukurac9b0f1a2013-04-23 16:28:24 -040094 # REVISIT(rkukura): Setting firewall_driver here for
Mark McClainb05c8762013-07-06 23:29:39 -040095 # neutron.agent.securitygroups_rpc.is_firewall_enabled() which is
Bob Kukurac9b0f1a2013-04-23 16:28:24 -040096 # used in the server, in case no L2 agent is configured on the
97 # server's node. If an L2 agent is configured, this will get
98 # overridden with the correct driver. The ml2 plugin should
99 # instead use its own config variable to indicate whether security
100 # groups is enabled, and that will need to be set here instead.
101 if [[ "$Q_USE_SECGROUP" == "True" ]]; then
Akihiro Motoki4074e292014-02-14 00:54:58 +0900102 iniset /$Q_PLUGIN_CONF_FILE securitygroup firewall_driver neutron.agent.not.a.real.FirewallDriver
Bob Kukurac9b0f1a2013-04-23 16:28:24 -0400103 else
Akihiro Motoki4074e292014-02-14 00:54:58 +0900104 iniset /$Q_PLUGIN_CONF_FILE securitygroup firewall_driver neutron.agent.firewall.NoopFirewallDriver
Bob Kukurac9b0f1a2013-04-23 16:28:24 -0400105 fi
106
Kyle Mesteryb7726592013-07-19 14:26:53 +0000107 # Since we enable the tunnel TypeDrivers, also enable a local_ip
Edgar Magana6f335b92014-07-10 15:42:44 -0700108 iniset /$Q_PLUGIN_CONF_FILE ovs local_ip $TUNNEL_ENDPOINT_IP
Kyle Mesteryb7726592013-07-19 14:26:53 +0000109
Akihiro Motoki130c90e2013-11-28 16:56:51 +0900110 populate_ml2_config /$Q_PLUGIN_CONF_FILE ml2 mechanism_drivers=$Q_ML2_PLUGIN_MECHANISM_DRIVERS
Kyle Mestery3ea28ec2013-08-05 12:24:32 +0000111
Akihiro Motoki130c90e2013-11-28 16:56:51 +0900112 populate_ml2_config /$Q_PLUGIN_CONF_FILE ml2 type_drivers=$Q_ML2_PLUGIN_TYPE_DRIVERS
Kyle Mesteryb7726592013-07-19 14:26:53 +0000113
Akihiro Motoki130c90e2013-11-28 16:56:51 +0900114 populate_ml2_config /$Q_PLUGIN_CONF_FILE ml2 $Q_SRV_EXTRA_OPTS
Kyle Mesteryb7726592013-07-19 14:26:53 +0000115
Akihiro Motoki130c90e2013-11-28 16:56:51 +0900116 populate_ml2_config /$Q_PLUGIN_CONF_FILE ml2_type_gre $Q_ML2_PLUGIN_GRE_TYPE_OPTIONS
Kyle Mesteryb7726592013-07-19 14:26:53 +0000117
Akihiro Motoki130c90e2013-11-28 16:56:51 +0900118 populate_ml2_config /$Q_PLUGIN_CONF_FILE ml2_type_vxlan $Q_ML2_PLUGIN_VXLAN_TYPE_OPTIONS
Kyle Mesteryb7726592013-07-19 14:26:53 +0000119
yunhong jiang73d32162014-10-06 09:34:35 -0700120 populate_ml2_config /$Q_PLUGIN_CONF_FILE ml2_type_flat $Q_ML2_PLUGIN_FLAT_TYPE_OPTIONS
121
Akihiro Motoki130c90e2013-11-28 16:56:51 +0900122 populate_ml2_config /$Q_PLUGIN_CONF_FILE ml2_type_vlan $Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS
Brian Haleyeea76212014-06-27 11:45:50 -0400123
124 if [[ "$Q_DVR_MODE" != "legacy" ]]; then
125 populate_ml2_config /$Q_PLUGIN_CONF_FILE agent l2_population=True
126 populate_ml2_config /$Q_PLUGIN_CONF_FILE agent tunnel_types=vxlan
127 populate_ml2_config /$Q_PLUGIN_CONF_FILE agent enable_distributed_routing=True
128 fi
Bob Kukurac9b0f1a2013-04-23 16:28:24 -0400129}
130
Ian Wienandaee18c72014-02-21 15:35:08 +1100131function has_neutron_plugin_security_group {
Bob Kukurac9b0f1a2013-04-23 16:28:24 -0400132 return 0
133}
134
135# Restore xtrace
Dean Troyere3a91602014-03-28 12:40:56 -0500136$ML2_XTRACE