Failed pg_connect leaves Network Socket in CLOSE_WAIT State
| Bug #27007 | Failed pg_connect leaves Network Socket in CLOSE_WAIT State | ||||
|---|---|---|---|---|---|
| Submitted: | 2004-01-22 12:16 UTC | Modified: | 2004-01-28 21:49 UTC | ||
| From: | bty at requesttech dot com | Assigned: | |||
| Status: | Closed | Package: | PostgreSQL related | ||
| PHP Version: | 4.3.4 | OS: | RedHat 9 | ||
| Private report: | No | CVE-ID: | None | ||
[2004-01-22 12:16 UTC] bty at requesttech dot com
Description:
------------
When a database connection to postgres fails the assocaited socket is not closed by PHP but kept in a CLOSE_WAIT state. When doing a tcpdump if the PostgreSQL sends a FIN first the final FIN packet is not Sent by PHP leaving the socket in CLOSE_WAIT.
I have checked bug reports 9252 and 16356.
This IS PHPs problem as it does not correctly send the FIN packet (probably a if( GOT_FIN ) close( socket ) missing from the code) when the PostgreSQL server (or any service) sends FIN first.
This is a serious issue as the only way to remove the CLOSE_WAIT sockets is to restart the web server. It is obvious that PHP is not doing something correct.
Reproduce code:
---------------
$resource_id = pg_connect( "host=good dbname=good user=good password=good" );
pg_close( $resource_id );
//This will put the socket in a TIME_WAIT state and will
//close in a matter of minutes
for( $i=0; $i < 1024; $i++ ) {
$resource_id = pg_connect( "host=good dbname=good user=good password=bad" );
if( $resource_id )
pg_close( $resource_id );
}
//Towards the end of this loop, connections will be refused
//because too many sockets are open.
//The sockets remain in the CLOSE_WAIT state until the web
//server is rebooted
Expected result:
----------------
Sockets are closed by the final sending of a FIN packet from PHP.
Actual result:
--------------
Sockets are left in CLOSE_WAIT until the web server is rebooted.
Patches
Pull Requests
History
AllCommentsChangesGit/SVN commits
[2004-01-28 21:38 UTC] bty at requesttech dot com
[2004-01-28 21:49 UTC] iliaa@php.net