relayd: add LTTNG_RELAYD_HEALTH env var
authorMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Wed, 22 Jan 2014 19:48:07 +0000 (14:48 -0500)
committerDavid Goulet <dgoulet@efficios.com>
Tue, 28 Jan 2014 20:19:51 +0000 (15:19 -0500)
Allow override of path leading to health check named pipe.

Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
doc/man/lttng-relayd.8
src/bin/lttng-relayd/health-relayd.c
src/bin/lttng-relayd/health-relayd.h

index 76d8ee3573003e9e907536bca2aa041d01e11a73..045ac7a1095a42ac00b40877caebec2ad33002b0 100644 (file)
@@ -71,6 +71,8 @@ Show version number
 Control timeout of socket connection, receive and send. Takes an integer
 parameter: the timeout value, in milliseconds. A value of 0 or -1 uses
 the timeout of the operating system (this is the default).
+.IP "LTTNG_RELAYD_HEALTH"
+File path used for relay daemon health check communication.
 .PP
 
 .SH "SEE ALSO"
index 6b4a742f8e5fa95066e29b3e922ff13bd449eb31..01e54d2eae795a35e87d94dd6f06b51ef96be3ac 100644 (file)
@@ -53,7 +53,8 @@
 #include "health-relayd.h"
 
 /* Global health check unix path */
-static char health_unix_sock_path[PATH_MAX];
+static
+char health_unix_sock_path[PATH_MAX];
 
 int health_quit_pipe[2];
 
@@ -129,12 +130,32 @@ error:
        return ret;
 }
 
+static
+int parse_health_env(void)
+{
+       const char *health_path;
+
+       health_path = getenv(LTTNG_RELAYD_HEALTH_ENV);
+       if (health_path) {
+               strncpy(health_unix_sock_path, health_path,
+                       PATH_MAX);
+               health_unix_sock_path[PATH_MAX - 1] = '\0';
+       }
+
+       return 0;
+}
+
 static
 int setup_health_path(void)
 {
        int is_root, ret = 0;
        char *home_path = NULL, *rundir = NULL, *relayd_path;
 
+       ret = parse_health_env();
+       if (ret) {
+               return ret;
+       }
+
        is_root = !getuid();
 
        if (is_root) {
index 6bfb73b5a8023fd276e87cf3cb7b23e860ed52d6..7c7b6e7497cdf4aeffbc35fb9b262a4768261ec4 100644 (file)
  * Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
  */
 
+#include <limits.h>
 #include <lttng/health-internal.h>
 
+#define LTTNG_RELAYD_HEALTH_ENV                "LTTNG_RELAYD_HEALTH"
+
 enum health_type_relayd {
        HEALTH_RELAYD_TYPE_DISPATCHER           = 0,
        HEALTH_RELAYD_TYPE_WORKER               = 1,
This page took 0.028136 seconds and 5 git commands to generate.