Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 1 | # Neutron Modular Layer 2 plugin |
Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 2 | # ------------------------------ |
| 3 | |
| 4 | # Save trace setting |
| 5 | MY_XTRACE=$(set +o | grep xtrace) |
| 6 | set +o xtrace |
| 7 | |
Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 8 | # Enable this to simply and quickly enable tunneling with ML2. |
| 9 | # Select either 'gre', 'vxlan', or '(gre vxlan)' |
| 10 | Q_ML2_TENANT_NETWORK_TYPE=${Q_ML2_TENANT_NETWORK_TYPE:-} |
| 11 | # This has to be set here since the agent will set this in the config file |
| 12 | if [[ "$Q_ML2_TENANT_NETWORK_TYPE" != "" ]]; then |
| 13 | Q_AGENT_EXTRA_AGENT_OPTS=(tunnel_types=$Q_ML2_TENANT_NETWORK_TYPE) |
| 14 | elif [[ "$ENABLE_TENANT_TUNNELS" = "True" ]]; then |
| 15 | Q_AGENT_EXTRA_AGENT_OPTS=(tunnel_types=gre) |
| 16 | fi |
| 17 | |
Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 18 | # Default openvswitch L2 agent |
| 19 | Q_AGENT=${Q_AGENT:-openvswitch} |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 20 | source $TOP_DIR/lib/neutron_plugins/${Q_AGENT}_agent |
Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 21 | |
Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 22 | # List of MechanismDrivers to load |
Kyle Mestery | bc63247 | 2013-09-06 14:59:30 +0000 | [diff] [blame^] | 23 | Q_ML2_PLUGIN_MECHANISM_DRIVERS=${Q_ML2_PLUGIN_MECHANISM_DRIVERS:-openvswitch,linuxbridge} |
Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 24 | # List of Type Drivers to load |
| 25 | Q_ML2_PLUGIN_TYPE_DRIVERS=${Q_ML2_PLUGIN_TYPE_DRIVERS:-local,flat,vlan,gre,vxlan} |
| 26 | # Default GRE TypeDriver options |
| 27 | Q_ML2_PLUGIN_GRE_TYPE_OPTIONS=${Q_ML2_PLUGIN_GRE_TYPE_OPTIONS:-tunnel_id_ranges=$TENANT_TUNNEL_RANGES} |
| 28 | # Default VXLAN TypeDriver options |
| 29 | Q_ML2_PLUGIN_VXLAN_TYPE_OPTIONS=${Q_ML2_PLUGIN_VXLAN_TYPE_OPTIONS:-vni_ranges=1001:2000} |
| 30 | # Default VLAN TypeDriver options |
| 31 | Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS=${Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS:-} |
| 32 | |
| 33 | function populate_ml2_config() { |
| 34 | OPTS=$1 |
| 35 | CONF=$2 |
| 36 | SECTION=$3 |
| 37 | |
| 38 | for I in "${OPTS[@]}"; do |
| 39 | # Replace the first '=' with ' ' for iniset syntax |
| 40 | iniset $CONF $SECTION ${I/=/ } |
| 41 | done |
| 42 | } |
| 43 | |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 44 | function neutron_plugin_configure_common() { |
| 45 | Q_PLUGIN_CONF_PATH=etc/neutron/plugins/ml2 |
Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 46 | Q_PLUGIN_CONF_FILENAME=ml2_conf.ini |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 47 | Q_DB_NAME="neutron_ml2" |
| 48 | Q_PLUGIN_CLASS="neutron.plugins.ml2.plugin.Ml2Plugin" |
Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 49 | } |
| 50 | |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 51 | function neutron_plugin_configure_service() { |
Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 52 | if [[ "$Q_ML2_TENANT_NETWORK_TYPE" != "" ]]; then |
| 53 | Q_SRV_EXTRA_OPTS=(tenant_network_types=$Q_ML2_TENANT_NETWORK_TYPE) |
| 54 | elif [[ "$ENABLE_TENANT_TUNNELS" = "True" ]]; then |
| 55 | # This assumes you want a simple configuration, and will overwrite |
| 56 | # Q_SRV_EXTRA_OPTS if set in addition to ENABLE_TENANT_TUNNELS. |
| 57 | Q_SRV_EXTRA_OPTS=(tenant_network_types=gre) |
| 58 | Q_ML2_PLUGIN_GRE_TYPE_OPTIONS=(tunnel_id_ranges=$TENANT_TUNNEL_RANGES) |
Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 59 | elif [[ "$ENABLE_TENANT_VLANS" = "True" ]]; then |
Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 60 | Q_SRV_EXTRA_OPTS=(tenant_network_types=vlan) |
Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 61 | else |
| 62 | echo "WARNING - The ml2 plugin is using local tenant networks, with no connectivity between hosts." |
| 63 | fi |
| 64 | |
Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 65 | # Allow for overrding VLAN configuration (for example, to configure provider |
| 66 | # VLANs) by first checking if Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS is set. |
| 67 | if [ "$Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS" == "" ]; then |
| 68 | if [[ "$ML2_VLAN_RANGES" = "" ]] && [[ "$PHYSICAL_NETWORK" != "" ]]; then |
| 69 | ML2_VLAN_RANGES=$PHYSICAL_NETWORK |
| 70 | if [[ "$TENANT_VLAN_RANGE" != "" ]]; then |
| 71 | ML2_VLAN_RANGES=$ML2_VLAN_RANGES:$TENANT_VLAN_RANGE |
| 72 | fi |
Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 73 | fi |
Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 74 | if [[ "$ML2_VLAN_RANGES" != "" ]]; then |
| 75 | Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS=(network_vlan_ranges=$ML2_VLAN_RANGES) |
| 76 | fi |
Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 77 | fi |
| 78 | |
| 79 | # REVISIT(rkukura): Setting firewall_driver here for |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 80 | # neutron.agent.securitygroups_rpc.is_firewall_enabled() which is |
Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 81 | # used in the server, in case no L2 agent is configured on the |
| 82 | # server's node. If an L2 agent is configured, this will get |
| 83 | # overridden with the correct driver. The ml2 plugin should |
| 84 | # instead use its own config variable to indicate whether security |
| 85 | # groups is enabled, and that will need to be set here instead. |
| 86 | if [[ "$Q_USE_SECGROUP" == "True" ]]; then |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 87 | iniset /$Q_PLUGIN_CONF_FILE SECURITYGROUP firewall_driver neutron.agent.not.a.real.FirewallDriver |
Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 88 | else |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 89 | iniset /$Q_PLUGIN_CONF_FILE SECURITYGROUP firewall_driver neutron.agent.firewall.NoopFirewallDriver |
Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 90 | fi |
| 91 | |
Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 92 | # Since we enable the tunnel TypeDrivers, also enable a local_ip |
| 93 | iniset /$Q_PLUGIN_CONF_FILE ovs local_ip $HOST_IP |
| 94 | |
Kyle Mestery | 3ea28ec | 2013-08-05 12:24:32 +0000 | [diff] [blame] | 95 | populate_ml2_config mechanism_drivers=$Q_ML2_PLUGIN_MECHANISM_DRIVERS /$Q_PLUGIN_CONF_FILE ml2 |
| 96 | |
Kyle Mestery | b772659 | 2013-07-19 14:26:53 +0000 | [diff] [blame] | 97 | populate_ml2_config type_drivers=$Q_ML2_PLUGIN_TYPE_DRIVERS /$Q_PLUGIN_CONF_FILE ml2 |
| 98 | |
| 99 | populate_ml2_config $Q_SRV_EXTRA_OPTS /$Q_PLUGIN_CONF_FILE ml2 |
| 100 | |
| 101 | populate_ml2_config $Q_ML2_PLUGIN_GRE_TYPE_OPTIONS /$Q_PLUGIN_CONF_FILE ml2_type_gre |
| 102 | |
| 103 | populate_ml2_config $Q_ML2_PLUGIN_VXLAN_TYPE_OPTIONS /$Q_PLUGIN_CONF_FILE ml2_type_vxlan |
| 104 | |
| 105 | if [ "$Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS" != "" ]; then |
| 106 | populate_ml2_config $Q_ML2_PLUGIN_VLAN_TYPE_OPTIONS /$Q_PLUGIN_CONF_FILE ml2_type_vlan |
| 107 | fi |
Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 108 | } |
| 109 | |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 110 | function has_neutron_plugin_security_group() { |
Bob Kukura | c9b0f1a | 2013-04-23 16:28:24 -0400 | [diff] [blame] | 111 | return 0 |
| 112 | } |
| 113 | |
| 114 | # Restore xtrace |
| 115 | $MY_XTRACE |