This prevents the "Server reached connection limit. Closing inbound
connection." issue we have been seeing in the
run-debuginfod-webapi-concurrency.sh testcase. From the manual:
If the connection limit is reached, MHD’s behavior depends a bit
on other options. If MHD_USE_ITC was given, MHD will stop
accepting connections on the listen socket. This will cause the
operating system to queue connections (up to the listen() limit)
above the connection limit. Those connections will be held until
MHD is done processing at least one of the active connections. If
MHD_USE_ITC is not set, then MHD will continue to accept() and
immediately close() these connections.
https://sourceware.org/bugzilla/show_bug.cgi?id=28708
Signed-off-by: Mark Wielaard <mark@klomp.org>
+2022-04-24 Mark Wielaard <mark@klomp.org>
+
+ * debuginfod.cxx (main): Add MHD_USE_ITC to MHD_start_daemon flags.
+
2022-04-13 Aaron Merey <amerey@redhat.com>
* debuginfod-client.c (debuginfod_query_server):
| MHD_USE_EPOLL
#endif
| MHD_USE_DUAL_STACK
+#if MHD_VERSION >= 0x00095200
+ | MHD_USE_ITC
+#endif
| MHD_USE_DEBUG, /* report errors to stderr */
http_port,
NULL, NULL, /* default accept policy */
+2022-04-24 Mark Wielaard <mark@klomp.org>
+
+ * run-debuginfod-webapi-concurrency.sh: Fix PR number in xfail.
+
2022-04-23 Mark Wielaard <mark@klomp.org>
* run-debuginfod-webapi-concurrency.sh: Lower parallel lookups.
PID1=0
done
-xfail "grep Server.reached.connection vlog$PORT1" # PR18661
+# Note this xfail comes too late, the above wait_ready for
+# http_responses_transfer_bytes_count will have failed.
+xfail "grep Server.reached.connection vlog$PORT1" # PR28661
exit 0