mirror of
https://github.com/openvswitch/ovs
synced 2025-10-25 15:07:05 +00:00
daemon-windows: unlink pidfile before stopping the service.
When a OVS daemon is configured to run as a Windows service, when the service is stopped by calling service_stop(), the windows services manager does not give enough time to do everything in the atexit handler. So call the exit handler directly from service_stop(). Also add a test case for Windows services which checks for the termination of the service by looking at pidfile cleaned by the exit handler. Signed-off-by: Gurucharan Shetty <gshetty@nicira.com Acked-by: Ben Pfaff <blp@nicira.com>
This commit is contained in:
@@ -218,6 +218,11 @@ should_service_stop(void)
|
||||
void
|
||||
service_stop()
|
||||
{
|
||||
if (!service_started) {
|
||||
return;
|
||||
}
|
||||
fatal_signal_atexit_handler();
|
||||
|
||||
ResetEvent(wevent);
|
||||
CloseHandle(wevent);
|
||||
|
||||
|
||||
@@ -64,7 +64,6 @@ static volatile sig_atomic_t stored_sig_nr = SIG_ATOMIC_MAX;
|
||||
|
||||
static struct ovs_mutex mutex;
|
||||
|
||||
static void atexit_handler(void);
|
||||
static void call_hooks(int sig_nr);
|
||||
#ifdef _WIN32
|
||||
static BOOL WINAPI ConsoleHandlerRoutine(DWORD dwCtrlType);
|
||||
@@ -115,7 +114,7 @@ fatal_signal_init(void)
|
||||
}
|
||||
#endif
|
||||
}
|
||||
atexit(atexit_handler);
|
||||
atexit(fatal_signal_atexit_handler);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -226,8 +225,8 @@ fatal_ignore_sigpipe(void)
|
||||
#endif
|
||||
}
|
||||
|
||||
static void
|
||||
atexit_handler(void)
|
||||
void
|
||||
fatal_signal_atexit_handler(void)
|
||||
{
|
||||
call_hooks(0);
|
||||
}
|
||||
|
||||
@@ -31,6 +31,7 @@ void fatal_signal_fork(void);
|
||||
void fatal_signal_run(void);
|
||||
void fatal_signal_wait(void);
|
||||
void fatal_ignore_sigpipe(void);
|
||||
void fatal_signal_atexit_handler(void);
|
||||
|
||||
/* Convenience functions for unlinking files upon termination.
|
||||
*
|
||||
|
||||
@@ -159,3 +159,28 @@ AT_CHECK([grep 'ovsdb-server: could not initialize control socket' stderr],
|
||||
[0], [ignore], [])
|
||||
AT_CHECK([test ! -s pid])
|
||||
AT_CLEANUP
|
||||
|
||||
AT_SETUP([daemon --service])
|
||||
AT_SKIP_IF([test "$IS_WIN32" != "yes"])
|
||||
OVSDB_INIT([db])
|
||||
AT_CAPTURE_FILE([pid])
|
||||
# To create a Windows service, we need the absolute path for the executable.
|
||||
abs_path="$(cd $(dirname `which ovsdb-server`); pwd -W; cd $OLDPWD)"
|
||||
|
||||
AT_CHECK([sc create ovsdb-server binpath="$abs_path/ovsdb-server `pwd`/db --log-file=`pwd`/ovsdb-server.log --pidfile=`pwd`/pid --remote=punix:`pwd`/socket --unixctl=`pwd`/unixctl --service"],
|
||||
[0], [[[SC]] CreateService SUCCESS
|
||||
])
|
||||
|
||||
AT_CHECK([sc start ovsdb-server], [0], [ignore])
|
||||
OVS_WAIT_UNTIL([test -s pid])
|
||||
AT_CHECK([sc query ovsdb-server | grep STATE | grep RUNNING], [0], [ignore])
|
||||
AT_CHECK([kill -0 `cat pid`], [0], [ignore])
|
||||
AT_CHECK([ovs-appctl -t `pwd`/unixctl ovsdb-server/list-dbs], [0],
|
||||
[Open_vSwitch
|
||||
])
|
||||
AT_CHECK([sc stop ovsdb-server], [0], [ignore])
|
||||
OVS_WAIT_UNTIL([test ! -s pid])
|
||||
AT_CHECK([sc query ovsdb-server | grep STATE | grep STOPPED], [0], [ignore])
|
||||
AT_CHECK([sc delete ovsdb-server], [0], [[[SC]] DeleteService SUCCESS
|
||||
])
|
||||
AT_CLEANUP
|
||||
|
||||
Reference in New Issue
Block a user