diff options
author | Pavel Březina <pbrezina@redhat.com> | 2012-09-27 20:57:51 +0200 |
---|---|---|
committer | Jakub Hrozek <jhrozek@redhat.com> | 2012-10-02 16:10:58 +0200 |
commit | fa893b2796b002f709e9416f134bc8df8c08cf8d (patch) | |
tree | c58b397422654aafa97ff00ab6eade186653bcf5 | |
parent | f3c6d7d83f1906369fc64a1480d1c014f693b0cd (diff) | |
download | sssd-fa893b2796b002f709e9416f134bc8df8c08cf8d.tar.gz sssd-fa893b2796b002f709e9416f134bc8df8c08cf8d.tar.bz2 sssd-fa893b2796b002f709e9416f134bc8df8c08cf8d.zip |
monitor: create pid file after all responders are started
https://fedorahosted.org/sssd/ticket/1357
-rw-r--r-- | src/monitor/monitor.c | 40 | ||||
-rw-r--r-- | src/util/util.h | 1 |
2 files changed, 37 insertions, 4 deletions
diff --git a/src/monitor/monitor.c b/src/monitor/monitor.c index 33248123..920d01c0 100644 --- a/src/monitor/monitor.c +++ b/src/monitor/monitor.c @@ -64,6 +64,9 @@ * doesn't shutdown on receiving SIGTERM */ #define MONITOR_DEF_FORCE_TIME 60 +/* name of the monitor server instance */ +#define MONITOR_NAME "sssd" + /* Special value to leave the Kerberos Replay Cache set to use * the libkrb5 defaults */ @@ -140,6 +143,8 @@ struct mt_ctx { struct sss_domain_info *domains; TALLOC_CTX *service_ctx; /* Memory context for services */ char **services; + int num_services; + int started_services; struct mt_svc *svc_list; struct sbus_connection *sbus_srv; struct config_file_ctx *file_ctx; @@ -345,6 +350,12 @@ static int svc_destructor(void *mem) talloc_set_destructor((TALLOC_CTX *)svc->conn_spy, NULL); talloc_zfree(svc->conn_spy); } + + if (svc->type == MT_SVC_SERVICE && svc->svc_started + && svc->mt_ctx != NULL && svc->mt_ctx->started_services > 0) { + svc->mt_ctx->started_services--; + } + return 0; } @@ -419,6 +430,23 @@ static int mark_service_as_started(struct mt_svc *svc) } } + if (svc->type == MT_SVC_SERVICE) { + ctx->started_services++; + } + + /* create the pid file if all services are alive */ + if (ctx->started_services == ctx->num_services) { + DEBUG(SSSDBG_TRACE_FUNC, ("All services have successfully started, " + "creating pid file\n")); + ret = pidfile(PID_PATH, MONITOR_NAME); + if (ret != EOK) { + DEBUG(SSSDBG_FATAL_FAILURE, + ("Error creating pidfile: %s/%s.pid! (%d [%s])\n", + PID_PATH, MONITOR_NAME, ret, strerror(ret))); + kill(getpid(), SIGTERM); + } + } + done: return ret; } @@ -789,6 +817,7 @@ int get_monitor_config(struct mt_ctx *ctx) int ret; int timeout_seconds; char *badsrv = NULL; + int i; ret = confdb_get_int(ctx->cdb, CONFDB_MONITOR_CONF_ENTRY, @@ -819,6 +848,12 @@ int get_monitor_config(struct mt_ctx *ctx) return EINVAL; } + ctx->started_services = 0; + ctx->num_services = 0; + for (i = 0; ctx->services[i] != NULL; i++) { + ctx->num_services++; + } + ctx->domain_ctx = talloc_new(ctx); if(!ctx->domain_ctx) { return ENOMEM; @@ -2518,9 +2553,6 @@ int main(int argc, const char *argv[]) return 6; } - /* we want a pid file check */ - flags |= FLAGS_PID_FILE; - /* Open before server_setup() does to have logging * during configuration checking */ if (debug_to_file) { @@ -2588,7 +2620,7 @@ int main(int argc, const char *argv[]) /* set up things like debug , signals, daemonization, etc... */ monitor->conf_path = CONFDB_MONITOR_CONF_ENTRY; - ret = server_setup("sssd", flags, monitor->conf_path, &main_ctx); + ret = server_setup(MONITOR_NAME, flags, monitor->conf_path, &main_ctx); if (ret != EOK) return 2; monitor->ev = main_ctx->event_ctx; diff --git a/src/util/util.h b/src/util/util.h index df739ab6..a96f519a 100644 --- a/src/util/util.h +++ b/src/util/util.h @@ -361,6 +361,7 @@ struct main_context { }; int die_if_parent_died(void); +int pidfile(const char *path, const char *name); int server_setup(const char *name, int flags, const char *conf_entry, struct main_context **main_ctx); |