Re: Intermittent etwork connection errors with apache. Restarting apache temporarily fixes the problem. PHP or apache problem?

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Mark,


> I don't have any disconnect call in my code.  

Is this the same for all your connections code, apart from your LDAP?  It's good practice to never assume that PHP will disconnect connections for you - explicitly call the disconnect function when your connection is done with.

> Lately I have noticed that the apache server will get into a state where connection requests will occasionally fail.  When I refresh the page, the connection almost always succeeds on the 2nd attempt.   If I restart the apache server, the problem totally goes away for a long period of time.   

Are you talking about the connection to Apache or the connection from your Apache server to your other servers?

> So I assume that somewhere, something is causing connections to stay opened when the script ends, rather than automatically closing them.

As I said above, always explicitly disconnect from any services you connect to when you're finished.

> 
> This error occurs with other types of network connections that the script makes (besides ldap), so it's not an ldap issue.
> 
> How does Apache automatically close connections when the script ends?  Is it possible that connections are being left opened?  Is there any way to debug the problem, i.e. to see if connections are left opened in some way?

Run "netstat -an|grep tcp" on the server's console before and after a page request - if possible prevent all other connections to your Apache server while you do it.

Connections that remain open will be in the state "ESTABLISHED" - server processes (e.g. Apache) will be listed as "LISTEN."

If you get an LDAP connection after your page request that wasn't there before in the ESTABLISHED state, PHP isn't disconnecting.

If any connections are listed as TIME_WAIT, it means the connection was dropped without the client disconnecting properly - it may be worth running netstat on your LDAP server as well.

Regards,
Andy
-- 
PHP General Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php



[Index of Archives]     [PHP Home]     [Apache Users]     [PHP on Windows]     [Kernel Newbies]     [PHP Install]     [PHP Classes]     [Pear]     [Postgresql]     [Postgresql PHP]     [PHP on Windows]     [PHP Database Programming]     [PHP SOAP]

  Powered by Linux