Modifications for Ubuntu 13.10: * Add .conf suffix to apache2 config files. In Ubuntu 13.10, files in sites-available should have ".conf" suffix. Otherwise it is not recognized by a2ensite. * libglib2.0-dev is added to lib/files/apt/trema. Trema is an OpenFlow controler framework used by Neutron NEC plugin Ubuntu package dependency seems to be changed. Minor cleanups are also done in OVS configuration: * Set datapath_id before connecting to the OpenFlow controller to ensure datapath_id changes after connected. Previously datapath_id is changed after connecting to the controller. * Drop "0x" prefix from datapath_id passed to OVS. OVS ignores datapath_id with 0x prefix. * Fix a bug that SKIP_OVS_BRIDGE_SETUP skips all confiugration of the plugin agent. It should skip only OVS setup. Change-Id: Ifac3def8decda577b5740c82fe8d24e8520c7777
		
			
				
	
	
		
			132 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			132 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
# Neutron NEC OpenFlow plugin
 | 
						|
# ---------------------------
 | 
						|
 | 
						|
# Save trace setting
 | 
						|
MY_XTRACE=$(set +o | grep xtrace)
 | 
						|
set +o xtrace
 | 
						|
 | 
						|
# Configuration parameters
 | 
						|
OFC_HOST=${OFC_HOST:-127.0.0.1}
 | 
						|
OFC_PORT=${OFC_PORT:-8888}
 | 
						|
 | 
						|
OFC_API_HOST=${OFC_API_HOST:-$OFC_HOST}
 | 
						|
OFC_API_PORT=${OFC_API_PORT:-$OFC_PORT}
 | 
						|
OFC_OFP_HOST=${OFC_OFP_HOST:-$OFC_HOST}
 | 
						|
OFC_OFP_PORT=${OFC_OFP_PORT:-6633}
 | 
						|
OFC_DRIVER=${OFC_DRIVER:-trema}
 | 
						|
OFC_RETRY_MAX=${OFC_RETRY_MAX:-0}
 | 
						|
OFC_RETRY_INTERVAL=${OFC_RETRY_INTERVAL:-1}
 | 
						|
 | 
						|
# Main logic
 | 
						|
# ---------------------------
 | 
						|
 | 
						|
source $TOP_DIR/lib/neutron_plugins/ovs_base
 | 
						|
 | 
						|
function neutron_plugin_create_nova_conf() {
 | 
						|
    _neutron_ovs_base_configure_nova_vif_driver
 | 
						|
}
 | 
						|
 | 
						|
function neutron_plugin_install_agent_packages() {
 | 
						|
    # SKIP_OVS_INSTALL is useful when we want to use Open vSwitch whose
 | 
						|
    # version is different from the version provided by the distribution.
 | 
						|
    if [[ "$SKIP_OVS_INSTALL" = "True" ]]; then
 | 
						|
        echo "You need to install Open vSwitch manually."
 | 
						|
        return
 | 
						|
    fi
 | 
						|
    _neutron_ovs_base_install_agent_packages
 | 
						|
}
 | 
						|
 | 
						|
function neutron_plugin_configure_common() {
 | 
						|
    Q_PLUGIN_CONF_PATH=etc/neutron/plugins/nec
 | 
						|
    Q_PLUGIN_CONF_FILENAME=nec.ini
 | 
						|
    Q_DB_NAME="neutron_nec"
 | 
						|
    Q_PLUGIN_CLASS="neutron.plugins.nec.nec_plugin.NECPluginV2"
 | 
						|
}
 | 
						|
 | 
						|
function neutron_plugin_configure_debug_command() {
 | 
						|
    _neutron_ovs_base_configure_debug_command
 | 
						|
}
 | 
						|
 | 
						|
function neutron_plugin_configure_dhcp_agent() {
 | 
						|
    :
 | 
						|
}
 | 
						|
 | 
						|
function neutron_plugin_configure_l3_agent() {
 | 
						|
    _neutron_ovs_base_configure_l3_agent
 | 
						|
}
 | 
						|
 | 
						|
function _quantum_plugin_setup_bridge() {
 | 
						|
    if [[ "$SKIP_OVS_BRIDGE_SETUP" = "True" ]]; then
 | 
						|
        return
 | 
						|
    fi
 | 
						|
    # Set up integration bridge
 | 
						|
    _neutron_ovs_base_setup_bridge $OVS_BRIDGE
 | 
						|
    # Generate datapath ID from HOST_IP
 | 
						|
    local dpid=$(printf "%07d%03d%03d%03d\n" ${HOST_IP//./ })
 | 
						|
    sudo ovs-vsctl --no-wait set Bridge $OVS_BRIDGE other-config:datapath-id=$dpid
 | 
						|
    sudo ovs-vsctl --no-wait set-fail-mode $OVS_BRIDGE secure
 | 
						|
    sudo ovs-vsctl --no-wait set-controller $OVS_BRIDGE tcp:$OFC_OFP_HOST:$OFC_OFP_PORT
 | 
						|
    if [ -n "$OVS_INTERFACE" ]; then
 | 
						|
        sudo ovs-vsctl --no-wait -- --may-exist add-port $OVS_BRIDGE $OVS_INTERFACE
 | 
						|
    fi
 | 
						|
    _neutron_setup_ovs_tunnels $OVS_BRIDGE
 | 
						|
}
 | 
						|
 | 
						|
function neutron_plugin_configure_plugin_agent() {
 | 
						|
    _quantum_plugin_setup_bridge
 | 
						|
 | 
						|
    AGENT_BINARY="$NEUTRON_BIN_DIR/neutron-nec-agent"
 | 
						|
 | 
						|
    _neutron_ovs_base_configure_firewall_driver
 | 
						|
}
 | 
						|
 | 
						|
function neutron_plugin_configure_service() {
 | 
						|
    iniset $NEUTRON_CONF DEFAULT api_extensions_path neutron/plugins/nec/extensions/
 | 
						|
    iniset /$Q_PLUGIN_CONF_FILE ofc host $OFC_API_HOST
 | 
						|
    iniset /$Q_PLUGIN_CONF_FILE ofc port $OFC_API_PORT
 | 
						|
    iniset /$Q_PLUGIN_CONF_FILE ofc driver $OFC_DRIVER
 | 
						|
    iniset /$Q_PLUGIN_CONF_FILE ofc api_retry_max OFC_RETRY_MAX
 | 
						|
    iniset /$Q_PLUGIN_CONF_FILE ofc api_retry_interval OFC_RETRY_INTERVAL
 | 
						|
 | 
						|
    _neutron_ovs_base_configure_firewall_driver
 | 
						|
}
 | 
						|
 | 
						|
function neutron_plugin_setup_interface_driver() {
 | 
						|
    local conf_file=$1
 | 
						|
    iniset $conf_file DEFAULT interface_driver neutron.agent.linux.interface.OVSInterfaceDriver
 | 
						|
    iniset $conf_file DEFAULT ovs_use_veth True
 | 
						|
}
 | 
						|
 | 
						|
# Utility functions
 | 
						|
# ---------------------------
 | 
						|
 | 
						|
# Setup OVS tunnel manually
 | 
						|
function _neutron_setup_ovs_tunnels() {
 | 
						|
    local bridge=$1
 | 
						|
    local id=0
 | 
						|
    GRE_LOCAL_IP=${GRE_LOCAL_IP:-$HOST_IP}
 | 
						|
    if [ -n "$GRE_REMOTE_IPS" ]; then
 | 
						|
        for ip in ${GRE_REMOTE_IPS//:/ }
 | 
						|
        do
 | 
						|
            if [[ "$ip" == "$GRE_LOCAL_IP" ]]; then
 | 
						|
                continue
 | 
						|
            fi
 | 
						|
            sudo ovs-vsctl --no-wait add-port $bridge gre$id -- \
 | 
						|
                set Interface gre$id type=gre options:remote_ip=$ip
 | 
						|
            id=`expr $id + 1`
 | 
						|
        done
 | 
						|
    fi
 | 
						|
}
 | 
						|
 | 
						|
function has_neutron_plugin_security_group() {
 | 
						|
    # 0 means True here
 | 
						|
    return 0
 | 
						|
}
 | 
						|
 | 
						|
function neutron_plugin_check_adv_test_requirements() {
 | 
						|
    is_service_enabled q-agt && is_service_enabled q-dhcp && return 0
 | 
						|
}
 | 
						|
 | 
						|
# Restore xtrace
 | 
						|
$MY_XTRACE
 |