Fix startup in systemd environments

Signed-off-by: Lon Hohberger <lon@users.sourceforge.net>
This commit is contained in:
Lon Hohberger 2012-02-07 16:03:05 -05:00
parent 9522be50d9
commit 19674ab0bd
2 changed files with 25 additions and 16 deletions

View File

@ -7,6 +7,8 @@ Requires=syslog.target network.target
WantedBy=multi-user.target
[Service]
Type=forking
Restart=on-failure
SysVStartPriority=99
Environment="FENCE_VIRTD_ARGS=-w"
# Autogenerated below here

View File

@ -53,7 +53,7 @@ main(int argc, char **argv)
const backend_plugin_t *p;
listener_context_t listener_ctx = NULL;
backend_context_t backend_ctx = NULL;
int debug_set = 0, foreground = 0, wait_for_backend = 0;
int debug_set = 0, foreground = 0, wait_for_init = 0;
int opt, configure = 0;
config = sc_init();
@ -81,7 +81,7 @@ main(int argc, char **argv)
configure = 1;
break;
case 'w':
wait_for_backend = 1;
wait_for_init = 1;
break;
case 'l':
plugin_dump();
@ -120,10 +120,10 @@ main(int argc, char **argv)
foreground = atoi(val);
}
if (!wait_for_backend) {
if (sc_get(config, "fence_virtd/@wait_for_backend",
if (!wait_for_init) {
if (sc_get(config, "fence_virtd/@wait_for_init",
val, sizeof(val)) == 0)
wait_for_backend = atoi(val);
wait_for_init = atoi(val);
}
if (dget() > 3)
@ -189,8 +189,10 @@ main(int argc, char **argv)
signal(SIGTERM, exit_handler);
signal(SIGQUIT, exit_handler);
syslog(LOG_NOTICE, "fence_virtd starting. Listener: %s Backend: %s", backend_name, listener_name);
while (p->init(&backend_ctx, config) < 0) {
if (!wait_for_backend) {
if (!wait_for_init) {
if (foreground) {
printf("Backend plugin %s failed to initialize\n",
backend_name);
@ -208,8 +210,9 @@ main(int argc, char **argv)
}
/* only client we have now is mcast (fence_xvm behavior) */
if (lp->init(&listener_ctx, p->callbacks, config, map,
backend_ctx) < 0) {
while (lp->init(&listener_ctx, p->callbacks, config, map,
backend_ctx) != 0) {
if (!wait_for_init)
if (foreground) {
printf("Listener plugin %s failed to initialize\n",
listener_name);
@ -219,9 +222,13 @@ main(int argc, char **argv)
listener_name);
return 1;
}
sleep(5);
}
while (run && lp->dispatch(listener_ctx, NULL) >= 0);
syslog(LOG_NOTICE, "fence_virtd shutting down");
map_release(map);
sc_release(config);