1
0
This repository has been archived on 2024-07-22. You can view files and clone it, but cannot push or open issues or pull requests.
Files
2024-07-22 01:58:46 -03:00

175 lines
4.8 KiB
Bash
Executable File

#! /bin/sh
# Copyright (c) 2011, 2013 Nicira, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at:
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
case $0 in
*/*) dir0=`echo "$0" | sed 's,/[^/]*$,,'` ;;
*) dir0=./ ;;
esac
. "$dir0/ovs-lib" || exit 1
usage() {
UTIL=$(basename $0)
cat <<EOF
${UTIL}: Provides helper functions to save Open vSwitch's configuration.
usage: $0 COMMAND
Commands:
save-interfaces Outputs a shell script on stdout that will restore
the current kernel configuration of the specified
network interfaces, as well as the system iptables
configuration.
save-flows Outputs a shell script on stdout that will restore
OpenFlow flows of each Open vSwitch bridge.
save-ofports Outputs a shell script on stdout that will restore
the ofport value across a force-reload-kmod.
This script is meant as a helper for the Open vSwitch init script commands.
EOF
}
save_interfaces () {
if (ip -V) > /dev/null 2>&1; then :; else
echo "$0: ip not found in $PATH" >&2
exit 1
fi
if test "$#" = 0; then
exit 0
fi
devs="$@"
for dev in $devs; do
state=`ip link show dev $dev` || continue
echo "# $dev"
# Link state (Ethernet addresses, up/down, ...)
linkcmd=
case $state in
*"state UP"* | *[,\<]"UP"[,\>]* )
linkcmd="$linkcmd up"
;;
*"state DOWN"*)
linkcmd="$linkcmd down"
;;
esac
if expr "$state" : '.*\bdynamic\b' > /dev/null; then
linkcmd="$linkcmd dynamic"
fi
if qlen=`expr "$state" : '.*qlen \([0-9]+\)'`; then
linkcmd="$linkcmd txqueuelen $qlen"
fi
if hwaddr=`expr "$state" : '.*link/ether \([^ ]*\)'`; then
linkcmd="$linkcmd address $hwaddr"
fi
if brd=`expr "$state" : '.*brd \([^ ]*\)'`; then
linkcmd="$linkcmd broadcast $brd"
fi
if mtu=`expr "$state" : '.*mtu \([0-9]+\)'`; then
linkcmd="$linkcmd mtu $mtu"
fi
if test -n "$linkcmd"; then
echo ip link set dev $dev down # Required to change hwaddr.
echo ip link set dev $dev $linkcmd
fi
move_ip_address $dev $dev
move_ip_routes $dev $dev
echo
done
if (iptables-save) > /dev/null 2>&1; then
echo "# global"
echo "iptables-restore <<'EOF'"
iptables-save
echo "EOF"
else
echo "# iptables-save not found in $PATH, not saving iptables state"
fi
}
save_flows () {
if (ovs-ofctl --version) > /dev/null 2>&1; then :; else
echo "$0: ovs-ofctl not found in $PATH" >&2
exit 1
fi
for bridge in "$@"; do
echo "ovs-ofctl add-flows ${bridge} - << EOF"
ovs-ofctl dump-flows "${bridge}" | sed -e '/NXST_FLOW/d' \
-e 's/\(idle\|hard\)_age=[^,]*,//g'
echo "EOF"
done
}
ovs_vsctl () {
ovs-vsctl --no-wait "$@"
}
save_ofports ()
{
if (ovs-vsctl --version) > /dev/null 2>&1; then :; else
echo "$0: ovs-vsctl not found in $PATH" >&2
exit 1
fi
for bridge in "$@"; do
count=0
for iface in `ovs_vsctl list-ifaces ${bridge}`; do
ofport=`ovs_vsctl get interface ${iface} ofport`
[ "${count}" -eq 0 ] && cmd="ovs-vsctl --no-wait"
cmd="${cmd} -- --if-exists set interface "${iface}" \
ofport_request="${ofport}""
# Run set interface command on 50 ports at a time.
count=`expr ${count} + 1`
[ "${count}" -eq 50 ] && count=0 && echo "${cmd}" && cmd=""
done
echo "${cmd}"
done
}
while [ $# -ne 0 ]
do
case $1 in
"save-flows")
shift
save_flows "$@"
exit 0
;;
"save-interfaces")
shift
save_interfaces "$@"
exit 0
;;
"save-ofports")
shift
save_ofports "$@"
exit 0
;;
-h | --help)
usage
exit 0
;;
*)
echo >&2 "$0: unknown command \"$1\" (use --help for help)"
exit 1
;;
esac
done
exit 0