mirror of
https://github.com/nginx/nginx.git
synced 2025-06-07 17:52:38 +08:00
Stream: proxy_requests directive.
The directive allows to drop binding between a client and existing UDP stream session after receiving a specified number of packets. First packet from the same client address and port will start a new session. Old session continues to exist and will terminate at moment defined by configuration: either after receiving the expected number of responses, or after timeout, as specified by the "proxy_responses" and/or "proxy_timeout" directives. By default, proxy_requests is zero (disabled).
This commit is contained in:
parent
abf04ed87a
commit
41a451e286
@ -509,6 +509,7 @@ void ngx_event_recvmsg(ngx_event_t *ev);
|
|||||||
void ngx_udp_rbtree_insert_value(ngx_rbtree_node_t *temp,
|
void ngx_udp_rbtree_insert_value(ngx_rbtree_node_t *temp,
|
||||||
ngx_rbtree_node_t *node, ngx_rbtree_node_t *sentinel);
|
ngx_rbtree_node_t *node, ngx_rbtree_node_t *sentinel);
|
||||||
#endif
|
#endif
|
||||||
|
void ngx_delete_udp_connection(void *data);
|
||||||
ngx_int_t ngx_trylock_accept_mutex(ngx_cycle_t *cycle);
|
ngx_int_t ngx_trylock_accept_mutex(ngx_cycle_t *cycle);
|
||||||
ngx_int_t ngx_enable_accept_events(ngx_cycle_t *cycle);
|
ngx_int_t ngx_enable_accept_events(ngx_cycle_t *cycle);
|
||||||
u_char *ngx_accept_log_error(ngx_log_t *log, u_char *buf, size_t len);
|
u_char *ngx_accept_log_error(ngx_log_t *log, u_char *buf, size_t len);
|
||||||
|
@ -23,7 +23,6 @@ static void ngx_close_accepted_udp_connection(ngx_connection_t *c);
|
|||||||
static ssize_t ngx_udp_shared_recv(ngx_connection_t *c, u_char *buf,
|
static ssize_t ngx_udp_shared_recv(ngx_connection_t *c, u_char *buf,
|
||||||
size_t size);
|
size_t size);
|
||||||
static ngx_int_t ngx_insert_udp_connection(ngx_connection_t *c);
|
static ngx_int_t ngx_insert_udp_connection(ngx_connection_t *c);
|
||||||
static void ngx_delete_udp_connection(void *data);
|
|
||||||
static ngx_connection_t *ngx_lookup_udp_connection(ngx_listening_t *ls,
|
static ngx_connection_t *ngx_lookup_udp_connection(ngx_listening_t *ls,
|
||||||
struct sockaddr *sockaddr, socklen_t socklen,
|
struct sockaddr *sockaddr, socklen_t socklen,
|
||||||
struct sockaddr *local_sockaddr, socklen_t local_socklen);
|
struct sockaddr *local_sockaddr, socklen_t local_socklen);
|
||||||
@ -558,11 +557,15 @@ ngx_insert_udp_connection(ngx_connection_t *c)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void
|
void
|
||||||
ngx_delete_udp_connection(void *data)
|
ngx_delete_udp_connection(void *data)
|
||||||
{
|
{
|
||||||
ngx_connection_t *c = data;
|
ngx_connection_t *c = data;
|
||||||
|
|
||||||
|
if (c->udp == NULL) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
ngx_rbtree_delete(&c->listening->rbtree, &c->udp->node);
|
ngx_rbtree_delete(&c->listening->rbtree, &c->udp->node);
|
||||||
|
|
||||||
c->udp = NULL;
|
c->udp = NULL;
|
||||||
@ -643,4 +646,12 @@ ngx_lookup_udp_connection(ngx_listening_t *ls, struct sockaddr *sockaddr,
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
void
|
||||||
|
ngx_delete_udp_connection(void *data)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -26,6 +26,7 @@ typedef struct {
|
|||||||
size_t buffer_size;
|
size_t buffer_size;
|
||||||
size_t upload_rate;
|
size_t upload_rate;
|
||||||
size_t download_rate;
|
size_t download_rate;
|
||||||
|
ngx_uint_t requests;
|
||||||
ngx_uint_t responses;
|
ngx_uint_t responses;
|
||||||
ngx_uint_t next_upstream_tries;
|
ngx_uint_t next_upstream_tries;
|
||||||
ngx_flag_t next_upstream;
|
ngx_flag_t next_upstream;
|
||||||
@ -195,6 +196,13 @@ static ngx_command_t ngx_stream_proxy_commands[] = {
|
|||||||
offsetof(ngx_stream_proxy_srv_conf_t, download_rate),
|
offsetof(ngx_stream_proxy_srv_conf_t, download_rate),
|
||||||
NULL },
|
NULL },
|
||||||
|
|
||||||
|
{ ngx_string("proxy_requests"),
|
||||||
|
NGX_STREAM_MAIN_CONF|NGX_STREAM_SRV_CONF|NGX_CONF_TAKE1,
|
||||||
|
ngx_conf_set_num_slot,
|
||||||
|
NGX_STREAM_SRV_CONF_OFFSET,
|
||||||
|
offsetof(ngx_stream_proxy_srv_conf_t, requests),
|
||||||
|
NULL },
|
||||||
|
|
||||||
{ ngx_string("proxy_responses"),
|
{ ngx_string("proxy_responses"),
|
||||||
NGX_STREAM_MAIN_CONF|NGX_STREAM_SRV_CONF|NGX_CONF_TAKE1,
|
NGX_STREAM_MAIN_CONF|NGX_STREAM_SRV_CONF|NGX_CONF_TAKE1,
|
||||||
ngx_conf_set_num_slot,
|
ngx_conf_set_num_slot,
|
||||||
@ -1341,11 +1349,14 @@ ngx_stream_proxy_process_connection(ngx_event_t *ev, ngx_uint_t from_upstream)
|
|||||||
|
|
||||||
} else {
|
} else {
|
||||||
if (s->connection->type == SOCK_DGRAM) {
|
if (s->connection->type == SOCK_DGRAM) {
|
||||||
if (pscf->responses == NGX_MAX_INT32_VALUE) {
|
|
||||||
|
if (pscf->responses == NGX_MAX_INT32_VALUE
|
||||||
|
|| (u->responses >= pscf->responses * u->requests))
|
||||||
|
{
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* successfully terminate timed out UDP session
|
* successfully terminate timed out UDP session
|
||||||
* with unspecified number of responses
|
* if expected number of responses was received
|
||||||
*/
|
*/
|
||||||
|
|
||||||
handler = c->log->handler;
|
handler = c->log->handler;
|
||||||
@ -1692,6 +1703,14 @@ ngx_stream_proxy_test_finalize(ngx_stream_session_t *s,
|
|||||||
|
|
||||||
if (c->type == SOCK_DGRAM) {
|
if (c->type == SOCK_DGRAM) {
|
||||||
|
|
||||||
|
if (pscf->requests && u->requests < pscf->requests) {
|
||||||
|
return NGX_DECLINED;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pscf->requests) {
|
||||||
|
ngx_delete_udp_connection(c);
|
||||||
|
}
|
||||||
|
|
||||||
if (pscf->responses == NGX_MAX_INT32_VALUE
|
if (pscf->responses == NGX_MAX_INT32_VALUE
|
||||||
|| u->responses < pscf->responses * u->requests)
|
|| u->responses < pscf->responses * u->requests)
|
||||||
{
|
{
|
||||||
@ -1943,6 +1962,7 @@ ngx_stream_proxy_create_srv_conf(ngx_conf_t *cf)
|
|||||||
conf->buffer_size = NGX_CONF_UNSET_SIZE;
|
conf->buffer_size = NGX_CONF_UNSET_SIZE;
|
||||||
conf->upload_rate = NGX_CONF_UNSET_SIZE;
|
conf->upload_rate = NGX_CONF_UNSET_SIZE;
|
||||||
conf->download_rate = NGX_CONF_UNSET_SIZE;
|
conf->download_rate = NGX_CONF_UNSET_SIZE;
|
||||||
|
conf->requests = NGX_CONF_UNSET_UINT;
|
||||||
conf->responses = NGX_CONF_UNSET_UINT;
|
conf->responses = NGX_CONF_UNSET_UINT;
|
||||||
conf->next_upstream_tries = NGX_CONF_UNSET_UINT;
|
conf->next_upstream_tries = NGX_CONF_UNSET_UINT;
|
||||||
conf->next_upstream = NGX_CONF_UNSET;
|
conf->next_upstream = NGX_CONF_UNSET;
|
||||||
@ -1987,6 +2007,9 @@ ngx_stream_proxy_merge_srv_conf(ngx_conf_t *cf, void *parent, void *child)
|
|||||||
ngx_conf_merge_size_value(conf->download_rate,
|
ngx_conf_merge_size_value(conf->download_rate,
|
||||||
prev->download_rate, 0);
|
prev->download_rate, 0);
|
||||||
|
|
||||||
|
ngx_conf_merge_uint_value(conf->requests,
|
||||||
|
prev->requests, 0);
|
||||||
|
|
||||||
ngx_conf_merge_uint_value(conf->responses,
|
ngx_conf_merge_uint_value(conf->responses,
|
||||||
prev->responses, NGX_MAX_INT32_VALUE);
|
prev->responses, NGX_MAX_INT32_VALUE);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user