diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/journal-remote/journal-gatewayd.c | 17 | ||||
| -rw-r--r-- | src/journal-remote/journal-remote.c | 5 | 
2 files changed, 19 insertions, 3 deletions
| diff --git a/src/journal-remote/journal-gatewayd.c b/src/journal-remote/journal-gatewayd.c index 29df842277..b839e5979b 100644 --- a/src/journal-remote/journal-gatewayd.c +++ b/src/journal-remote/journal-gatewayd.c @@ -1010,7 +1010,22 @@ int main(int argc, char *argv[]) {                          { MHD_OPTION_END, 0, NULL },                          { MHD_OPTION_END, 0, NULL }};                  int opts_pos = 2; -                int flags = MHD_USE_THREAD_PER_CONNECTION|MHD_USE_POLL|MHD_USE_DEBUG; + +                /* We force MHD_USE_PIPE_FOR_SHUTDOWN here, in order +                 * to make sure libmicrohttpd doesn't use shutdown() +                 * on our listening socket, which would break socket +                 * re-activation. See +                 * +                 * https://lists.gnu.org/archive/html/libmicrohttpd/2015-09/msg00014.html +                 * https://github.com/systemd/systemd/pull/1286 +                 */ + +                int flags = +                        MHD_USE_DEBUG | +                        MHD_USE_DUAL_STACK | +                        MHD_USE_PIPE_FOR_SHUTDOWN | +                        MHD_USE_POLL | +                        MHD_USE_THREAD_PER_CONNECTION;                  if (n > 0)                          opts[opts_pos++] = (struct MHD_OptionItem) diff --git a/src/journal-remote/journal-remote.c b/src/journal-remote/journal-remote.c index 50f41a575d..5354bf6e51 100644 --- a/src/journal-remote/journal-remote.c +++ b/src/journal-remote/journal-remote.c @@ -647,9 +647,10 @@ static int setup_microhttpd_server(RemoteServer *s,          int opts_pos = 3;          int flags =                  MHD_USE_DEBUG | -                MHD_USE_PEDANTIC_CHECKS | +                MHD_USE_DUAL_STACK |                  MHD_USE_EPOLL_LINUX_ONLY | -                MHD_USE_DUAL_STACK; +                MHD_USE_PEDANTIC_CHECKS | +                MHD_USE_PIPE_FOR_SHUTDOWN;          const union MHD_DaemonInfo *info;          int r, epoll_fd; | 
