Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
P
pve-manager
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Administrator
pve-manager
Commits
cc422b33
Commit
cc422b33
authored
Apr 16, 2013
by
Dietmar Maurer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
stop keep-alive when there are many open connections
We try to avoid to reach the max_conn limit.
parent
562cd9a4
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
7 additions
and
0 deletions
+7
-0
HTTPServer.pm
PVE/HTTPServer.pm
+7
-0
No files found.
PVE/HTTPServer.pm
View file @
cc422b33
...
@@ -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
})
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment