From 5852319bd4e26afeabb82b5de5eba7f07552616b Mon Sep 17 00:00:00 2001 From: qontinuum Date: Tue, 29 Nov 2022 21:34:06 +0100 Subject: Isolate warn_about_resource_exhaution() --- src/core/mainloop/connection.c | 29 ++++++++++++++++++----------- 1 file changed, 18 insertions(+), 11 deletions(-) (limited to 'src') diff --git a/src/core/mainloop/connection.c b/src/core/mainloop/connection.c index b0b297ac57..7de53e818f 100644 --- a/src/core/mainloop/connection.c +++ b/src/core/mainloop/connection.c @@ -1256,6 +1256,23 @@ create_unix_sockaddr(const char *listenaddress, char **readable_address, } #endif /* defined(HAVE_SYS_UN_H) || defined(RUNNING_DOXYGEN) */ +/* Log a rate-limited warning about resource exhaustion */ +static void +warn_about_resource_exhaution(void) +{ +#define WARN_TOO_MANY_CONNS_INTERVAL (6*60*60) + static ratelim_t last_warned = RATELIM_INIT(WARN_TOO_MANY_CONNS_INTERVAL); + char *m; + if ((m = rate_limit_log(&last_warned, approx_time()))) { + int n_conns = get_n_open_sockets(); + log_warn(LD_NET,"Failing because we have %d connections already. Please " + "read doc/TUNING for guidance.%s", n_conns, m); + tor_free(m); + control_event_general_status(LOG_WARN, "TOO_MANY_CONNECTIONS CURRENT=%d", + n_conns); + } +} + /** * A socket failed from resource exhaustion. * @@ -1284,17 +1301,7 @@ socket_failed_from_resource_exhaustion(void) rep_hist_note_overload(OVERLOAD_FD_EXHAUSTED); } -#define WARN_TOO_MANY_CONNS_INTERVAL (6*60*60) - static ratelim_t last_warned = RATELIM_INIT(WARN_TOO_MANY_CONNS_INTERVAL); - char *m; - if ((m = rate_limit_log(&last_warned, approx_time()))) { - int n_conns = get_n_open_sockets(); - log_warn(LD_NET,"Failing because we have %d connections already. Please " - "read doc/TUNING for guidance.%s", n_conns, m); - tor_free(m); - control_event_general_status(LOG_WARN, "TOO_MANY_CONNECTIONS CURRENT=%d", - n_conns); - } + warn_about_resource_exhaution(); } #ifdef HAVE_SYS_UN_H -- cgit v1.2.3-54-g00ecf From 7dd55c29f9d8119b1ca2c63d85d9d9fda865c451 Mon Sep 17 00:00:00 2001 From: qontinuum Date: Tue, 29 Nov 2022 21:43:14 +0100 Subject: Replace socket_failed_from_resource_exhaustion() by socket_failed_from_fd_exhaustion() --- src/core/mainloop/connection.c | 38 +++++++++----------------------------- 1 file changed, 9 insertions(+), 29 deletions(-) (limited to 'src') diff --git a/src/core/mainloop/connection.c b/src/core/mainloop/connection.c index 7de53e818f..f2fc5ea3fb 100644 --- a/src/core/mainloop/connection.c +++ b/src/core/mainloop/connection.c @@ -1274,33 +1274,13 @@ warn_about_resource_exhaution(void) } /** - * A socket failed from resource exhaustion. + * A socket failed from file descriptor exhaustion. * - * Among other actions, warn that an accept or a connect has failed because - * we're running out of TCP sockets we can use on current system. Rate-limit - * these warnings so that we don't spam the log. */ -static void -socket_failed_from_resource_exhaustion(void) + * Note down file descriptor exhaustion and log a warning. */ +static inline void +socket_failed_from_fd_exhaustion(void) { - /* When we get to this point we know that a socket could not be - * established. However the kernel does not let us know whether the reason is - * because we ran out of TCP source ports, or because we exhausted all the - * FDs on this system, or for any other reason. - * - * For this reason, we are going to use the following heuristic: If our - * system supports a lot of sockets, we will assume that it's a problem of - * TCP port exhaustion. Otherwise, if our system does not support many - * sockets, we will assume that this is because of file descriptor - * exhaustion. - */ - if (get_max_sockets() > 65535) { - /* TCP port exhaustion */ - rep_hist_note_tcp_exhaustion(); - } else { - /* File descriptor exhaustion */ - rep_hist_note_overload(OVERLOAD_FD_EXHAUSTED); - } - + rep_hist_note_overload(OVERLOAD_FD_EXHAUSTED); warn_about_resource_exhaution(); } @@ -1519,7 +1499,7 @@ connection_listener_new(const struct sockaddr *listensockaddr, if (!SOCKET_OK(s)) { int e = tor_socket_errno(s); if (ERRNO_IS_RESOURCE_LIMIT(e)) { - socket_failed_from_resource_exhaustion(); + socket_failed_from_fd_exhaustion(); /* * We'll call the OOS handler at the error exit, so set the * exhaustion flag for it. @@ -1645,7 +1625,7 @@ connection_listener_new(const struct sockaddr *listensockaddr, if (! SOCKET_OK(s)) { int e = tor_socket_errno(s); if (ERRNO_IS_RESOURCE_LIMIT(e)) { - socket_failed_from_resource_exhaustion(); + socket_failed_from_fd_exhaustion(); /* * We'll call the OOS handler at the error exit, so set the * exhaustion flag for it. @@ -1958,7 +1938,7 @@ connection_handle_listener_read(connection_t *conn, int new_type) connection_check_oos(get_n_open_sockets(), 0); return 0; } else if (ERRNO_IS_RESOURCE_LIMIT(e)) { - socket_failed_from_resource_exhaustion(); + socket_failed_from_fd_exhaustion(); /* Exhaustion; tell the OOS handler */ connection_check_oos(get_n_open_sockets(), 1); return 0; @@ -2227,7 +2207,7 @@ connection_connect_sockaddr,(connection_t *conn, */ *socket_error = tor_socket_errno(s); if (ERRNO_IS_RESOURCE_LIMIT(*socket_error)) { - socket_failed_from_resource_exhaustion(); + socket_failed_from_fd_exhaustion(); connection_check_oos(get_n_open_sockets(), 1); } else { log_warn(LD_NET,"Error creating network socket: %s", -- cgit v1.2.3-54-g00ecf