Sean Dague | e263c82 | 2014-12-05 14:25:28 -0500 | [diff] [blame] | 1 | #!/bin/bash |
| 2 | # |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 3 | # common functions for ovs based plugin |
| 4 | # ------------------------------------- |
| 5 | |
| 6 | # Save trace setting |
Dean Troyer | e3a9160 | 2014-03-28 12:40:56 -0500 | [diff] [blame] | 7 | OVSB_XTRACE=$(set +o | grep xtrace) |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 8 | set +o xtrace |
| 9 | |
JordanP | 614202f | 2013-05-16 11:16:13 +0200 | [diff] [blame] | 10 | OVS_BRIDGE=${OVS_BRIDGE:-br-int} |
| 11 | PUBLIC_BRIDGE=${PUBLIC_BRIDGE:-br-ex} |
James Chapman | c83cc75 | 2014-06-11 19:29:26 +0100 | [diff] [blame] | 12 | OVS_DATAPATH_TYPE=${OVS_DATAPATH_TYPE:-""} |
JordanP | 614202f | 2013-05-16 11:16:13 +0200 | [diff] [blame] | 13 | |
Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 14 | function is_neutron_ovs_base_plugin { |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 15 | # Yes, we use OVS. |
| 16 | return 0 |
| 17 | } |
| 18 | |
Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 19 | function _neutron_ovs_base_setup_bridge { |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 20 | local bridge=$1 |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 21 | neutron-ovs-cleanup |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 22 | sudo ovs-vsctl --no-wait -- --may-exist add-br $bridge |
James Chapman | c83cc75 | 2014-06-11 19:29:26 +0100 | [diff] [blame] | 23 | if [[ $OVS_DATAPATH_TYPE != "" ]]; then |
| 24 | sudo ovs-vsctl set Bridge $bridge datapath_type=${OVS_DATAPATH_TYPE} |
| 25 | fi |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 26 | sudo ovs-vsctl --no-wait br-set-external-id $bridge bridge-id $bridge |
| 27 | } |
| 28 | |
Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 29 | function neutron_ovs_base_cleanup { |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 30 | # remove all OVS ports that look like Neutron created ports |
Zhenzan Zhou | 9a70448 | 2015-01-27 10:48:24 +0800 | [diff] [blame^] | 31 | for port in $(sudo ovs-vsctl list port | grep -o -e [a-zA-Z\-]*tap[0-9a-f\-]* -e q[rg]-[0-9a-f\-]*); do |
JordanP | 614202f | 2013-05-16 11:16:13 +0200 | [diff] [blame] | 32 | sudo ovs-vsctl del-port ${port} |
| 33 | done |
| 34 | |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 35 | # remove all OVS bridges created by Neutron |
JordanP | 614202f | 2013-05-16 11:16:13 +0200 | [diff] [blame] | 36 | for bridge in $(sudo ovs-vsctl list-br | grep -o -e ${OVS_BRIDGE} -e ${PUBLIC_BRIDGE}); do |
| 37 | sudo ovs-vsctl del-br ${bridge} |
| 38 | done |
| 39 | } |
| 40 | |
Kyle Mestery | 86af4a0 | 2014-06-24 11:07:54 +0000 | [diff] [blame] | 41 | function _neutron_ovs_base_install_ubuntu_dkms { |
| 42 | # install Dynamic Kernel Module Support packages if needed |
| 43 | local kernel_version=$(uname -r) |
| 44 | local kernel_major_minor=`echo $kernel_version | cut -d. -f1-2` |
| 45 | # From kernel 3.13 on, openvswitch-datapath-dkms is not needed |
| 46 | if [ `vercmp_numbers "$kernel_major_minor" "3.13"` -lt "0" ]; then |
| 47 | install_package "dkms openvswitch-datapath-dkms linux-headers-$kernel_version" |
| 48 | fi |
| 49 | } |
| 50 | |
Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 51 | function _neutron_ovs_base_install_agent_packages { |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 52 | # Install deps |
Kyle Mestery | 86af4a0 | 2014-06-24 11:07:54 +0000 | [diff] [blame] | 53 | install_package $(get_packages "openvswitch") |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 54 | if is_ubuntu; then |
Kyle Mestery | 86af4a0 | 2014-06-24 11:07:54 +0000 | [diff] [blame] | 55 | _neutron_ovs_base_install_ubuntu_dkms |
Sean M. Collins | d738a9e | 2014-08-28 15:32:44 -0400 | [diff] [blame] | 56 | restart_service openvswitch-switch |
Gary Kotton | 5452b18 | 2013-02-25 13:02:38 +0000 | [diff] [blame] | 57 | elif is_fedora; then |
Gary Kotton | 5452b18 | 2013-02-25 13:02:38 +0000 | [diff] [blame] | 58 | restart_service openvswitch |
| 59 | elif is_suse; then |
Vincent Untz | cf6d809 | 2013-07-04 09:59:34 +0200 | [diff] [blame] | 60 | restart_service openvswitch-switch |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 61 | fi |
| 62 | } |
| 63 | |
Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 64 | function _neutron_ovs_base_configure_debug_command { |
YAMAMOTO Takashi | 98a0ad4 | 2014-11-21 10:42:18 +0900 | [diff] [blame] | 65 | if [ "$Q_USE_PROVIDERNET_FOR_PUBLIC" = "True" ]; then |
| 66 | iniset $NEUTRON_TEST_CONFIG_FILE DEFAULT external_network_bridge "" |
| 67 | else |
| 68 | iniset $NEUTRON_TEST_CONFIG_FILE DEFAULT external_network_bridge $PUBLIC_BRIDGE |
| 69 | fi |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 70 | } |
| 71 | |
Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 72 | function _neutron_ovs_base_configure_firewall_driver { |
Akihiro MOTOKI | 3452f8e | 2013-03-21 14:11:27 +0900 | [diff] [blame] | 73 | if [[ "$Q_USE_SECGROUP" == "True" ]]; then |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 74 | 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] | 75 | else |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 76 | iniset /$Q_PLUGIN_CONF_FILE securitygroup firewall_driver neutron.agent.firewall.NoopFirewallDriver |
Akihiro MOTOKI | 3452f8e | 2013-03-21 14:11:27 +0900 | [diff] [blame] | 77 | fi |
| 78 | } |
| 79 | |
Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 80 | function _neutron_ovs_base_configure_l3_agent { |
YAMAMOTO Takashi | 6a633fd | 2014-07-23 12:02:18 +0900 | [diff] [blame] | 81 | if [ "$Q_USE_PROVIDERNET_FOR_PUBLIC" = "True" ]; then |
| 82 | iniset $Q_L3_CONF_FILE DEFAULT external_network_bridge "" |
| 83 | else |
| 84 | iniset $Q_L3_CONF_FILE DEFAULT external_network_bridge $PUBLIC_BRIDGE |
| 85 | fi |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 86 | |
Mark McClain | b05c876 | 2013-07-06 23:29:39 -0400 | [diff] [blame] | 87 | neutron-ovs-cleanup |
YAMAMOTO Takashi | 0f18c23 | 2014-09-12 23:44:58 +0900 | [diff] [blame] | 88 | if [[ "$Q_USE_PUBLIC_VETH" = "True" ]]; then |
| 89 | ip link show $Q_PUBLIC_VETH_INT > /dev/null 2>&1 || |
| 90 | sudo ip link add $Q_PUBLIC_VETH_INT type veth \ |
| 91 | peer name $Q_PUBLIC_VETH_EX |
| 92 | sudo ip link set $Q_PUBLIC_VETH_INT up |
| 93 | sudo ip link set $Q_PUBLIC_VETH_EX up |
| 94 | sudo ip addr flush dev $Q_PUBLIC_VETH_EX |
| 95 | else |
| 96 | # --no-wait causes a race condition if $PUBLIC_BRIDGE is not up when ip addr flush is called |
| 97 | sudo ovs-vsctl -- --may-exist add-br $PUBLIC_BRIDGE |
| 98 | sudo ovs-vsctl br-set-external-id $PUBLIC_BRIDGE bridge-id $PUBLIC_BRIDGE |
| 99 | # ensure no IP is configured on the public bridge |
| 100 | sudo ip addr flush dev $PUBLIC_BRIDGE |
| 101 | fi |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 102 | } |
| 103 | |
Ian Wienand | aee18c7 | 2014-02-21 15:35:08 +1100 | [diff] [blame] | 104 | function _neutron_ovs_base_configure_nova_vif_driver { |
Aaron Rosen | 4540d00 | 2013-10-24 13:59:33 -0700 | [diff] [blame] | 105 | : |
Akihiro MOTOKI | 3452f8e | 2013-03-21 14:11:27 +0900 | [diff] [blame] | 106 | } |
| 107 | |
Isaku Yamahata | 0dd34df | 2012-12-28 13:15:31 +0900 | [diff] [blame] | 108 | # Restore xtrace |
Dean Troyer | e3a9160 | 2014-03-28 12:40:56 -0500 | [diff] [blame] | 109 | $OVSB_XTRACE |