是在WIN下开发,配置是nignx+php+mysql。
在项目中写一个curl操作的a.php文件,请求相同项目下的一个b.php文件,然后curl请求超时,就是一直在转圈,没有返回。
先看一下nginx中的配置
location ~ \.php(.*)$ { fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_split_path_info ^((?U).+\.php)(/?.+)$; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param PATH_INFO $fastcgi_path_info; fastcgi_param PATH_TRANSLATED $document_root$fastcgi_path_info; include fastcgi_params; }
然后查了一下,有人提到NGINX中,PHP文件块fastcig-pass的设置值(127.0.0.1:9000)。设置都是以keepalive方式请求,接收到PHP文件时,交于后端过程PHPCGI解析处理(127.0.0.1:9000),等待响应。而在本地文件以CURL请求本地环境中PHP文件时,之前的PHP还在等待CURL后的结果,这时9000端口已经被占用。导致CURL一直在处于等待状态。不设置timeout超时,程序就会卡死。结果都是false
在这里就是我执行一个curl操作的a.php文件,这个时候php-cgi开始处理a.php,然而这个a.php还没处理完,当前的端口被占用,所以无法请求b.php
这个b.php要等a.php处理完之后,才有不会占用当前端口,而要处理完b.php必须先处理好a.php,所以curl一直处于等待状态,程序卡死
解决方法:
1.新开启一个phpcgi进程设置不同端口:
E:\phpStudy\php70n\php-cgi.exe -b 127.0.0.1:9001 -c E:\phpStudy\php70n\php.ini
2.然后在需要被CURL的端口或域名设置中设置
location ~ \.php(.*)$ { fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_split_path_info ^((?U).+\.php)(/?.+)$; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param PATH_INFO $fastcgi_path_info; fastcgi_param PATH_TRANSLATED $document_root$fastcgi_path_info; include fastcgi_params; }
这样子设置完成后就可以正常访问了。