Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 1 | # common functions for ovs based plugin |
| 2 | # ------------------------------------- |
| 3 | |
| 4 | # Save trace setting |
Dean Troyer | 8d55be3 | 2013-02-07 17:16:35 -0600 | [diff] [blame] | 5 | MY_XTRACE=$(set +o | grep xtrace) |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 6 | set +o xtrace |
| 7 | |
JordanP | 614202f | 2013-05-16 11:16:13 +0200 | [diff] [blame] | 8 | OVS_BRIDGE=${OVS_BRIDGE:-br-int} |
| 9 | PUBLIC_BRIDGE=${PUBLIC_BRIDGE:-br-ex} |
| 10 | |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 11 | function is_neutron_ovs_base_plugin() { |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 12 | # Yes, we use OVS. |
| 13 | return 0 |
| 14 | } |
| 15 | |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 16 | function _neutron_ovs_base_setup_bridge() { |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 17 | local bridge=$1 |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 18 | neutron-ovs-cleanup |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 19 | sudo ovs-vsctl --no-wait -- --may-exist add-br $bridge |
| 20 | sudo ovs-vsctl --no-wait br-set-external-id $bridge bridge-id $bridge |
| 21 | } |
| 22 | |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 23 | function neutron_ovs_base_cleanup() { |
| 24 | # remove all OVS ports that look like Neutron created ports |
JordanP | 614202f | 2013-05-16 11:16:13 +0200 | [diff] [blame] | 25 | for port in $(sudo ovs-vsctl list port | grep -o -e tap[0-9a-f\-]* -e q[rg]-[0-9a-f\-]*); do |
| 26 | sudo ovs-vsctl del-port ${port} |
| 27 | done |
| 28 | |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 29 | # remove all OVS bridges created by Neutron |
JordanP | 614202f | 2013-05-16 11:16:13 +0200 | [diff] [blame] | 30 | for bridge in $(sudo ovs-vsctl list-br | grep -o -e ${OVS_BRIDGE} -e ${PUBLIC_BRIDGE}); do |
| 31 | sudo ovs-vsctl del-br ${bridge} |
| 32 | done |
| 33 | } |
| 34 | |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 35 | function _neutron_ovs_base_install_agent_packages() { |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 36 | local kernel_version |
| 37 | # Install deps |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 38 | # FIXME add to ``files/apts/neutron``, but don't install if not needed! |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 39 | if is_ubuntu; then |
| 40 | kernel_version=`cat /proc/version | cut -d " " -f3` |
| 41 | install_package make fakeroot dkms openvswitch-switch openvswitch-datapath-dkms linux-headers-$kernel_version |
Gary Kotton | 5452b18 | 2013-02-25 13:02:38 +0000 | [diff] [blame] | 42 | elif is_fedora; then |
| 43 | install_package openvswitch |
| 44 | # Ensure that the service is started |
| 45 | restart_service openvswitch |
| 46 | elif is_suse; then |
Vincent Untz | cf6d809 | 2013-07-04 09:59:34 +0200 | [diff] [blame] | 47 | install_package openvswitch |
| 48 | restart_service openvswitch-switch |
| 49 | restart_service openvswitch-controller |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 50 | fi |
| 51 | } |
| 52 | |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 53 | function _neutron_ovs_base_configure_debug_command() { |
| 54 | iniset $NEUTRON_TEST_CONFIG_FILE DEFAULT external_network_bridge $PUBLIC_BRIDGE |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 55 | } |
| 56 | |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 57 | function _neutron_ovs_base_configure_firewall_driver() { |
Akihiro MOTOKI | 3452f8e | 2013-03-21 14:11:27 +0900 | [diff] [blame] | 58 | if [[ "$Q_USE_SECGROUP" == "True" ]]; then |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 59 | iniset /$Q_PLUGIN_CONF_FILE securitygroup firewall_driver neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver |
Akihiro MOTOKI | 3452f8e | 2013-03-21 14:11:27 +0900 | [diff] [blame] | 60 | else |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 61 | iniset /$Q_PLUGIN_CONF_FILE securitygroup firewall_driver neutron.agent.firewall.NoopFirewallDriver |
Akihiro MOTOKI | 3452f8e | 2013-03-21 14:11:27 +0900 | [diff] [blame] | 62 | fi |
| 63 | } |
| 64 | |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 65 | function _neutron_ovs_base_configure_l3_agent() { |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 66 | iniset $Q_L3_CONF_FILE DEFAULT external_network_bridge $PUBLIC_BRIDGE |
| 67 | |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 68 | neutron-ovs-cleanup |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 69 | sudo ovs-vsctl --no-wait -- --may-exist add-br $PUBLIC_BRIDGE |
Gary Kotton | 503e9ac | 2013-07-15 09:41:25 -0700 | [diff] [blame] | 70 | sudo ovs-vsctl --no-wait br-set-external-id $PUBLIC_BRIDGE bridge-id $PUBLIC_BRIDGE |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 71 | # ensure no IP is configured on the public bridge |
| 72 | sudo ip addr flush dev $PUBLIC_BRIDGE |
| 73 | } |
| 74 | |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 75 | function _neutron_ovs_base_configure_nova_vif_driver() { |
| 76 | # The hybrid VIF driver needs to be specified when Neutron Security Group |
Akihiro MOTOKI | 3452f8e | 2013-03-21 14:11:27 +0900 | [diff] [blame] | 77 | # is enabled (until vif_security attributes are supported in VIF extension) |
| 78 | if [[ "$Q_USE_SECGROUP" == "True" ]]; then |
| 79 | NOVA_VIF_DRIVER=${NOVA_VIF_DRIVER:-"nova.virt.libvirt.vif.LibvirtHybridOVSBridgeDriver"} |
| 80 | else |
| 81 | NOVA_VIF_DRIVER=${NOVA_VIF_DRIVER:-"nova.virt.libvirt.vif.LibvirtGenericVIFDriver"} |
| 82 | fi |
| 83 | } |
| 84 | |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 85 | # Restore xtrace |
Dean Troyer | 8d55be3 | 2013-02-07 17:16:35 -0600 | [diff] [blame] | 86 | $MY_XTRACE |