我有一个运行报表的PHP应用程序,并在90秒内向SQL服务器发出大约100万次SQL查询。在这段时间内,没有其他人可以使用这个基于网络的应用程序 - 蛋计时器正在滚动,但是直到报告超时或完成才会加载。我在一个孤立的环境中测试了这个问题,只有我自己在那里,在浏览器中运行报告,然后从其他浏览器窗口到此应用程序站点的任何操作都被挂起。php并发请求被卡住了?
对测试环境的一些细节:在IIS
Windows 2008 R2 x64 - IIS 7.5 - PHP 5.3.8 via FastCGI
Windows 2008 R2 x64 - SQL Server 2008 R2 x64
FastCGI的设置:
Instance MaxRequests = 200
Max Instances = 16
Activity Timeout = 70
Idle Timeout = 300
Queue Length = 1000
Rapid Fails PerMin = 10
Request Timeout = 90
每个SQL请求完成小于60毫秒的SQL服务器端。 Web服务器和SQL服务器的CPU负载均小于10%。运行报告时,Web服务器有16GB RAM和大约60%的RAM可用。
看来,PHP一直发射了太多要求,SQL服务器,成为太忙,无法处理其他请求。如果是这种情况,那么应该有一些我可以调整来让PHP处理更多的并发请求。
有谁知道吗?请帮忙!
会话锁定? –
出于好奇,您是否尝试过通过完全不同的浏览器访问网站(例如,使用Firefox for one和Chrome for another)。只是试图排除这个想法,也许这只是你的会议被锁定,而不是整个网站。使用不同的浏览器会导致创建多个会话。同一浏览器中的不同标签会共享同一个会话。 –
查看[this](http://stackoverflow.com/questions/12070345/php-multiple-ajax-requests-first-request-block-second-request/12070517)问题。可能你有同样的问题 –