ID:               27007
 Updated by:       [EMAIL PROTECTED]
 Reported By:      bty at requesttech dot com
-Status:           Open
+Status:           Bogus
 Bug Type:         PostgreSQL related
 Operating System: RedHat 9
 PHP Version:      4.3.4
 New Comment:

This is by design, actual closing of connections happens during request
shutdown. Doing such for loop is pretty insane anyway, don't you think?
:)




Previous Comments:
------------------------------------------------------------------------

[2004-01-22 12:16:20] 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.


------------------------------------------------------------------------


-- 
Edit this bug report at http://bugs.php.net/?id=27007&edit=1

Reply via email to