Commit cc422b33 authored by Dietmar Maurer's avatar Dietmar Maurer

stop keep-alive when there are many open connections

We try to avoid to reach the max_conn limit.
parent 562cd9a4
...@@ -931,6 +931,11 @@ sub accept_connections { ...@@ -931,6 +931,11 @@ sub accept_connections {
my $reqstate = { keep_alive => $self->{keep_alive} }; my $reqstate = { keep_alive => $self->{keep_alive} };
# stop keep-alive when there are many open connections
if ($self->{conn_count} >= $self->{max_conn_soft_limit}) {
$reqstate->{keep_alive} = 0;
}
if (my $sin = getpeername($clientfh)) { if (my $sin = getpeername($clientfh)) {
my ($pport, $phost) = Socket::unpack_sockaddr_in($sin); my ($pport, $phost) = Socket::unpack_sockaddr_in($sin);
($reqstate->{peer_port}, $reqstate->{peer_host}) = ($pport, Socket::inet_ntoa($phost)); ($reqstate->{peer_port}, $reqstate->{peer_host}) = ($pport, Socket::inet_ntoa($phost));
...@@ -1048,6 +1053,8 @@ sub new { ...@@ -1048,6 +1053,8 @@ sub new {
$self->open_access_log($self->{logfile}) if $self->{logfile}; $self->open_access_log($self->{logfile}) if $self->{logfile};
$self->{max_conn_soft_limit} = $self->{max_conn} > 100 ? $self->{max_conn} - 20 : $self->{max_conn};
$self->{socket_watch} = AnyEvent->io(fh => $self->{socket}, poll => 'r', cb => sub { $self->{socket_watch} = AnyEvent->io(fh => $self->{socket}, poll => 'r', cb => sub {
eval { eval {
if ($self->{conn_count} >= $self->{max_conn}) { if ($self->{conn_count} >= $self->{max_conn}) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment