Skip to content

Commit

Permalink
debian: force-reload-kmod while package upgrading.
Browse files Browse the repository at this point in the history
Currently, when we upgrade openvswitch packages, we do a restart
of userspace daemons automatically. This does not replace the
kernel module.

But almost everytime, we want to use the new kernel module
that comes with the new version. This means that we need to
manually do a "force-reload-kmod". This step, reloads the
kernel module and also restarts the userspace daemons. This gives
us a total of two restarts of userspace daemons. This is quite
expensive in a hypervisor with hundreds of VMs sending real traffic.
This also hurts the controller as it gets two reconnections in a short
amount of time.

With this patch, during a package upgrade, if the kernel module
on disk is different than the one that is loaded, we will
automatically do a force-reload-kmod while openvswitch-switch
is installed. If not, we will just do a "restart" like before.

One can install the kernel package first and then install the userspace
packages in 2 separate steps to enforce a single 'force-reload-kmod'.

If anyone wants to just restart the userspace package instead of
force-reload-kmod, they can set the value of OVS_FORCE_RELOAD_KMOD=no
while installing the package.
Ex: OVS_FORCE_RELOAD_KMOD=no dpkg -i openvswitch-switch*

Signed-off-by: Gurucharan Shetty <[email protected]>
  • Loading branch information
shettyg committed Apr 23, 2013
1 parent ff23db3 commit 19cbf2b
Show file tree
Hide file tree
Showing 3 changed files with 36 additions and 6 deletions.
31 changes: 28 additions & 3 deletions debian/openvswitch-switch.init
Original file line number Diff line number Diff line change
Expand Up @@ -75,10 +75,35 @@ stop () {
}

restart () {
# OVS_RESTART_SAVE_FLOWS can be set by package postinst script.
if [ "$OVS_RESTART_SAVE_FLOWS" = "yes" ] || \
[ "$1" = "--save-flows=yes" ]; then
# OVS_FORCE_RELOAD_KMOD can be set by package postinst script.
if [ "$1" = "--save-flows=yes" ] || \
[ "${OVS_FORCE_RELOAD_KMOD}" = "no" ]; then
start restart
elif [ "${OVS_FORCE_RELOAD_KMOD}" = "yes" ]; then
depmod -a

if [ -e /sys/module/openvswitch ]; then
LOADED_SRCVERSION=`cat /sys/module/openvswitch/srcversion`
LOADED_VERSION=`cat /sys/module/openvswitch/version`
elif [ -e /sys/module/openvswitch_mod ]; then
LOADED_SRCVERSION=`cat /sys/module/openvswitch_mod/srcversion`
LOADED_VERSION=`cat /sys/module/openvswitch_mod/version`
fi
SRCVERSION=`modinfo -F srcversion openvswitch 2>/dev/null`
VERSION=`modinfo -F version openvswitch 2>/dev/null`

ovs_ctl_log "Package upgrading:\n"\
"Loaded version: ${LOADED_VERSION} ${LOADED_SRCVERSION}.\n"\
"Version on disk: ${VERSION} ${SRCVERSION}."

# If the kernel module was previously loaded and it is different than
# the kernel module on disk, then do a 'force-reload-kmod'.
if [ -n "${LOADED_SRCVERSION}" ] && [ -n "${SRCVERSION}" ] && \
[ "${SRCVERSION}" != "${LOADED_SRCVERSION}" ]; then
start force-reload-kmod
else
start restart
fi
else
stop
start
Expand Down
7 changes: 4 additions & 3 deletions debian/openvswitch-switch.postinst
Original file line number Diff line number Diff line change
Expand Up @@ -49,9 +49,10 @@ esac
OVS_MISSING_KMOD_OK=yes
export OVS_MISSING_KMOD_OK

# Save and restore openflow flows during a package upgrade.
OVS_RESTART_SAVE_FLOWS=yes
export OVS_RESTART_SAVE_FLOWS
# force-reload-kmod during upgrade. If a user wants to override this,
# they can set the variable OVS_FORCE_RELOAD_KMOD=no while installing.
[ -z "${OVS_FORCE_RELOAD_KMOD}" ] && OVS_FORCE_RELOAD_KMOD=yes || true
export OVS_FORCE_RELOAD_KMOD

#DEBHELPER#

Expand Down
4 changes: 4 additions & 0 deletions utilities/ovs-lib.in
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,10 @@ else
dbdir='@DBDIR@'
fi

ovs_ctl_log () {
echo "$@" >> "${logdir}/ovs-ctl.log"
}

ovs_ctl () {
case "$@" in
*"=strace"*)
Expand Down

0 comments on commit 19cbf2b

Please sign in to comment.