| # common functions for ovs based plugin |
| # ------------------------------------- |
| |
| # Save trace setting |
| MY_XTRACE=$(set +o | grep xtrace) |
| set +o xtrace |
| |
| OVS_BRIDGE=${OVS_BRIDGE:-br-int} |
| PUBLIC_BRIDGE=${PUBLIC_BRIDGE:-br-ex} |
| |
| function is_neutron_ovs_base_plugin() { |
| # Yes, we use OVS. |
| return 0 |
| } |
| |
| function _neutron_ovs_base_setup_bridge() { |
| local bridge=$1 |
| neutron-ovs-cleanup |
| sudo ovs-vsctl --no-wait -- --may-exist add-br $bridge |
| sudo ovs-vsctl --no-wait br-set-external-id $bridge bridge-id $bridge |
| } |
| |
| function neutron_ovs_base_cleanup() { |
| # remove all OVS ports that look like Neutron created ports |
| for port in $(sudo ovs-vsctl list port | grep -o -e tap[0-9a-f\-]* -e q[rg]-[0-9a-f\-]*); do |
| sudo ovs-vsctl del-port ${port} |
| done |
| |
| # remove all OVS bridges created by Neutron |
| for bridge in $(sudo ovs-vsctl list-br | grep -o -e ${OVS_BRIDGE} -e ${PUBLIC_BRIDGE}); do |
| sudo ovs-vsctl del-br ${bridge} |
| done |
| } |
| |
| function _neutron_ovs_base_install_agent_packages() { |
| local kernel_version |
| # Install deps |
| # FIXME add to ``files/apts/neutron``, but don't install if not needed! |
| if is_ubuntu; then |
| kernel_version=`cat /proc/version | cut -d " " -f3` |
| install_package make fakeroot dkms openvswitch-switch openvswitch-datapath-dkms linux-headers-$kernel_version |
| elif is_fedora; then |
| install_package openvswitch |
| # Ensure that the service is started |
| restart_service openvswitch |
| elif is_suse; then |
| install_package openvswitch |
| restart_service openvswitch-switch |
| restart_service openvswitch-controller |
| fi |
| } |
| |
| function _neutron_ovs_base_configure_debug_command() { |
| iniset $NEUTRON_TEST_CONFIG_FILE DEFAULT external_network_bridge $PUBLIC_BRIDGE |
| } |
| |
| function _neutron_ovs_base_configure_firewall_driver() { |
| if [[ "$Q_USE_SECGROUP" == "True" ]]; then |
| iniset /$Q_PLUGIN_CONF_FILE securitygroup firewall_driver neutron.agent.linux.iptables_firewall.OVSHybridIptablesFirewallDriver |
| else |
| iniset /$Q_PLUGIN_CONF_FILE securitygroup firewall_driver neutron.agent.firewall.NoopFirewallDriver |
| fi |
| } |
| |
| function _neutron_ovs_base_configure_l3_agent() { |
| iniset $Q_L3_CONF_FILE DEFAULT external_network_bridge $PUBLIC_BRIDGE |
| |
| neutron-ovs-cleanup |
| sudo ovs-vsctl --no-wait -- --may-exist add-br $PUBLIC_BRIDGE |
| sudo ovs-vsctl --no-wait br-set-external-id $PUBLIC_BRIDGE bridge-id $PUBLIC_BRIDGE |
| # ensure no IP is configured on the public bridge |
| sudo ip addr flush dev $PUBLIC_BRIDGE |
| } |
| |
| function _neutron_ovs_base_configure_nova_vif_driver() { |
| : |
| } |
| |
| # Restore xtrace |
| $MY_XTRACE |