]> git.ipfire.org Git - thirdparty/haproxy.git/commitdiff
BUG/MEDIUM: unix: completely unbind abstract sockets during a pause()
authorWilly Tarreau <w@1wt.eu>
Mon, 7 Jul 2014 19:07:51 +0000 (21:07 +0200)
committerWilly Tarreau <w@1wt.eu>
Mon, 7 Jul 2014 23:13:35 +0000 (01:13 +0200)
Abstract namespace sockets ignore the shutdown() call and do not make
it possible to temporarily stop listening. The issue it causes is that
during a soft reload, the new process cannot bind, complaining that the
address is already in use.

This change registers a new pause() function for unix sockets and
completely unbinds the abstract ones since it's possible to rebind
them later. It requires the two previous patches as well as preceeding
fixes.

This fix should be backported into 1.5 since the issue apperas there.

include/proto/proto_uxst.h
src/proto_uxst.c

index 9422ea7c2bcfc771946e961072ddb7bd7f9d42fc..8e796ecd170a46a507c1a089efd66a0645608ea4 100644 (file)
@@ -27,6 +27,7 @@
 #include <types/task.h>
 
 void uxst_add_listener(struct listener *listener);
+int uxst_pause_listener(struct listener *l);
 int uxst_get_src(int fd, struct sockaddr *sa, socklen_t salen, int dir);
 int uxst_get_dst(int fd, struct sockaddr *sa, socklen_t salen, int dir);
 
index 409c659064052d22fcf2b09f743b4d47d81e0c82..adc1b466032a3606e5b3e96e247a05f41e8fc60b 100644 (file)
@@ -68,6 +68,7 @@ static struct protocol proto_unix = {
        .disable_all = disable_all_listeners,
        .get_src = uxst_get_src,
        .get_dst = uxst_get_dst,
+       .pause = uxst_pause_listener,
        .listeners = LIST_HEAD_INIT(proto_unix.listeners),
        .nb_listeners = 0,
 };
@@ -373,6 +374,20 @@ void uxst_add_listener(struct listener *listener)
        proto_unix.nb_listeners++;
 }
 
+/* Pause a listener. Returns < 0 in case of failure, 0 if the listener
+ * was totally stopped, or > 0 if correctly paused. Nothing is done for
+ * plain unix sockets since currently it's the new process which handles
+ * the renaming. Abstract sockets are completely unbound.
+ */
+int uxst_pause_listener(struct listener *l)
+{
+       if (((struct sockaddr_un *)&l->addr)->sun_path[0])
+               return 1;
+
+       unbind_listener(l);
+       return 0;
+}
+
 
 /*
  * This function initiates a UNIX connection establishment to the target assigned