X-Git-Url: http://www.project-moonshot.org/gitweb/?p=trust_router.git;a=blobdiff_plain;f=mon%2Fmons.c;h=1d157aff36c3af5ac6d17bdebaa72e7bbcfdc479;hp=cb70d3b7767622044483ac70331fcf5fdade3454;hb=298aea2c08823da7e05747a072dffbcd485491c8;hpb=e2b95e95ffdc2e72afa22509cf3473e61090d03f diff --git a/mon/mons.c b/mon/mons.c index cb70d3b..1d157af 100644 --- a/mon/mons.c +++ b/mon/mons.c @@ -42,6 +42,7 @@ #include #include #include +#include #include #include "mons_handlers.h" @@ -214,6 +215,48 @@ int mons_get_listener(MONS_INSTANCE *mons, MONS_REQ_FUNC *req_handler, MONS_AUTH } /** + * Process to handle an incoming monitoring request + * + * This should be run in a child process after fork(). Handles the request + * and terminates. Never returns to the caller. + * + * @param mons the monitoring server instance + * @param conn_fd file descriptor for the incoming connection + */ +static void mons_handle_proc(MONS_INSTANCE *mons, int conn_fd) +{ + struct rlimit rlim; /* for disabling core dump */ + + switch(tr_gss_handle_connection(conn_fd, + "trustmonitor", mons->hostname, /* acceptor name */ + mons->auth_handler, mons->cookie, /* auth callback and cookie */ + mons_req_cb, mons /* req callback and cookie */ + )) { + case TR_GSS_SUCCESS: + /* do nothing */ + break; + + case TR_GSS_ERROR: + tr_debug("mons_accept: Error returned by tr_gss_handle_connection()"); + break; + + default: + tr_err("mons_accept: Unexpected value returned by tr_gss_handle_connection()"); + break; + } + close(conn_fd); + + /* This ought to be an exit(0), but log4shib does not play well with fork() due to + * threading issues. To ensure we do not get stuck in the exit handler, we will + * abort. First disable core dump for this subprocess (the main process will still + * dump core if the environment allows). */ + rlim.rlim_cur = 0; /* max core size of 0 */ + rlim.rlim_max = 0; /* prevent the core size limit from being raised later */ + setrlimit(RLIMIT_CORE, &rlim); + abort(); /* exit hard */ +} + +/** * Accept and process a connection on a port opened with mons_get_listener() * * @param mons monitoring interface instance @@ -236,18 +279,13 @@ int mons_accept(MONS_INSTANCE *mons, int listen) } if (pid == 0) { - close(listen); - tr_gss_handle_connection(conn, - "trustmonitor", mons->hostname, /* acceptor name */ - mons->auth_handler, mons->cookie, /* auth callback and cookie */ - mons_req_cb, mons /* req callback and cookie */ - ); - close(conn); - exit(0); /* exit to kill forked child process */ + /* Only the child process gets here */ + close(listen); /* this belongs to the parent */ + mons_handle_proc(mons, conn); /* never returns */ } /* Only the parent process gets here */ - close(conn); + close(conn); /* this belongs to the child */ g_array_append_val(mons->pids, pid); /* clean up any processes that have completed */