From 897b860e832c9eba67ba7d01d0775f64ade132f6 Mon Sep 17 00:00:00 2001 From: Igor Sysoev Date: Sat, 26 Aug 2017 13:37:39 +0300 Subject: Introduced nxt_socket_defer_accept(). --- src/nxt_socket.c | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) (limited to 'src/nxt_socket.c') diff --git a/src/nxt_socket.c b/src/nxt_socket.c index c174081c..b9bbac46 100644 --- a/src/nxt_socket.c +++ b/src/nxt_socket.c @@ -63,6 +63,27 @@ nxt_socket_close(nxt_task_t *task, nxt_socket_t s) } +void +nxt_socket_defer_accept(nxt_task_t *task, nxt_socket_t s, nxt_sockaddr_t *sa) +{ +#if (NXT_HAVE_UNIX_DOMAIN) + + if (sa->u.sockaddr.sa_family == AF_UNIX) { + /* Deferred accept() is not supported on AF_UNIX sockets. */ + return; + } + +#endif + +#ifdef TCP_DEFER_ACCEPT + + /* Defer Linux accept() up to for 1 second. */ + (void) nxt_socket_setsockopt(task, s, IPPROTO_TCP, TCP_DEFER_ACCEPT, 1); + +#endif +} + + nxt_int_t nxt_socket_getsockopt(nxt_task_t *task, nxt_socket_t s, nxt_uint_t level, nxt_uint_t sockopt) -- cgit