Introduced nxt_socket_defer_accept().
This commit is contained in:
@@ -78,16 +78,10 @@ nxt_listen_socket_create(nxt_task_t *task, nxt_listen_socket_t *ls,
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef TCP_DEFER_ACCEPT
|
|
||||||
|
|
||||||
if (ls->read_after_accept) {
|
if (ls->read_after_accept) {
|
||||||
/* Defer accept() maximum at 1 second. */
|
nxt_socket_defer_accept(task, s, sa);
|
||||||
/* Ignore possible error. TODO: why? */
|
|
||||||
(void) nxt_socket_setsockopt(task, s, IPPROTO_TCP, TCP_DEFER_ACCEPT, 1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
switch (nxt_socket_bind(task, s, sa, bind_test)) {
|
switch (nxt_socket_bind(task, s, sa, bind_test)) {
|
||||||
|
|
||||||
case NXT_OK:
|
case NXT_OK:
|
||||||
|
|||||||
@@ -1053,12 +1053,7 @@ nxt_router_listen_socket_ready(nxt_task_t *task, nxt_port_recv_msg_t *msg,
|
|||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef TCP_DEFER_ACCEPT
|
nxt_socket_defer_accept(task, s, rpc->socket_conf->sockaddr);
|
||||||
|
|
||||||
/* Defer Linux accept() up to for 1 second. */
|
|
||||||
(void) nxt_socket_setsockopt(task, s, IPPROTO_TCP, TCP_DEFER_ACCEPT, 1);
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
ret = nxt_listen_socket(task, s, NXT_LISTEN_BACKLOG);
|
ret = nxt_listen_socket(task, s, NXT_LISTEN_BACKLOG);
|
||||||
if (nxt_slow_path(ret != NXT_OK)) {
|
if (nxt_slow_path(ret != NXT_OK)) {
|
||||||
|
|||||||
@@ -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_int_t
|
||||||
nxt_socket_getsockopt(nxt_task_t *task, nxt_socket_t s, nxt_uint_t level,
|
nxt_socket_getsockopt(nxt_task_t *task, nxt_socket_t s, nxt_uint_t level,
|
||||||
nxt_uint_t sockopt)
|
nxt_uint_t sockopt)
|
||||||
|
|||||||
@@ -94,6 +94,8 @@ typedef union {
|
|||||||
NXT_EXPORT nxt_socket_t nxt_socket_create(nxt_task_t *task, nxt_uint_t family,
|
NXT_EXPORT nxt_socket_t nxt_socket_create(nxt_task_t *task, nxt_uint_t family,
|
||||||
nxt_uint_t type, nxt_uint_t protocol, nxt_uint_t flags);
|
nxt_uint_t type, nxt_uint_t protocol, nxt_uint_t flags);
|
||||||
NXT_EXPORT void nxt_socket_close(nxt_task_t *task, nxt_socket_t s);
|
NXT_EXPORT void nxt_socket_close(nxt_task_t *task, nxt_socket_t s);
|
||||||
|
NXT_EXPORT void nxt_socket_defer_accept(nxt_task_t *task, nxt_socket_t s,
|
||||||
|
nxt_sockaddr_t *sa);
|
||||||
NXT_EXPORT nxt_int_t nxt_socket_getsockopt(nxt_task_t *task, nxt_socket_t s,
|
NXT_EXPORT nxt_int_t nxt_socket_getsockopt(nxt_task_t *task, nxt_socket_t s,
|
||||||
nxt_uint_t level, nxt_uint_t sockopt);
|
nxt_uint_t level, nxt_uint_t sockopt);
|
||||||
NXT_EXPORT nxt_int_t nxt_socket_setsockopt(nxt_task_t *task, nxt_socket_t s,
|
NXT_EXPORT nxt_int_t nxt_socket_setsockopt(nxt_task_t *task, nxt_socket_t s,
|
||||||
|
|||||||
Reference in New Issue
Block a user