也是迁移业务遇到的,以前运维那哥们用的集成LAMP环境,现在迁移需要将Apache去掉,用php-cgi的模式来执行php,目前主流一般都是用php-fpm来管理php。

好了,前期就是将数据同步过来,然后再修改nginx配置,安装php-fpm,并启动php-fpm,会发现本地侦听9000端口,这里主要说下nginx配置:

原nginx配置,执行php方法:

Nginx支持put请求吗 nginx不支持put请求_PHP

看着这种配置比较蛋疼,然后换成cgi的模式:

 

 

注意fastcgi.conf里面需要将第一行删掉,以免前面的配置被覆盖了,其实这样的配置就欧了,也可以正常访问php文件,但是天不遂人愿,配置完了,在访问index.php,结果一直提示:

No input file specified,然后日志显示404,如下:

Nginx支持put请求吗 nginx不支持put请求_nginx_02

 

后面的200是将配置改为:

Nginx支持put请求吗 nginx不支持put请求_php_03

 

这里没用SCRIPT_FILENAME而是直接用SCRIPT_NAME这样可以显示200,写个phpinfo文件测试,无法执行php中的内容,很奇怪,LNMP环境也不复杂,只能慢慢的分析了,排除mysql,只是nginx与php通讯而已,还是查nginx。

‘SCRIPT_FILENAME’
当前执行脚本的绝对路径名(pathname)
‘SCRIPT_NAME’
含有当前脚本的路径。当页面需要指向他们自己时,有用. __FILE__ 常量包含路径和文件名

最后还是用SCRIPT_FILENAME,如果要用

fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

也是可以的,但必须保证 $document_root 被正确设置过

让我们看看PHP对这两个变量是怎么解释的吧
SCRIPT_NAME
SCRIPT_FILENAME
据说,必须指定正确的SCRIPT_FILENAME, PHP-CGI会忽略SCRIPT_NAME(即使它的值设置的是正确的)
或者指定特殊的php.ini, 设置doc_root, discard path, fix pathinfo等等

script_filename 只是被用做一种快捷方式。 如果fix_pathinfo设置打开,init函数将它用来决定真实的路径

因为配置文件会改变 nginx的变量$fastcgi_script_name

fastcgi_param SCRIPT_NAME /home/gavin/nginx/$fastcgi_script_name;
 fastcgi_param SCRIPT_FILENAME $fastcgi_script_name;和
fastcgi_param SCRIPT_FILENAME /home/gavin/nginx/$fastcgi_script_name;
 fastcgi_param SCRIPT_NAME $fastcgi_script_name;

这两种配置都是可以的

最后其实是php,ini文件问题,以前替换为php-5.2的ini文件,可能某些参数导致php无法执行,更换成原php.ini文件后测试访问正常。

下面是网上查询到的解决办法:

原因分析:
1、任何对.php文件的请求,都简单地交给php-cgi去处理,但没有验证该php文件是否存在。PHP文件不存在,没办法返回普通的404错误,它返回 一个404,并带上一句”No input file specified”

2、还可能跟 路径或者 权限有关系,或者SCRIPT_FILENAME 变量没有被正确的设置(这在nginx是最常见的原因)

1)如果html也出现404错误,那么就是document root 设置的有问题
2)检查脚本文件的权限, 可能PHP或者web server不能读取它
3)SCRIPT_FILENAME设置错误

1. 更改php.ini
首先php.ini的配置中把
;cgi.fix_pathinfo=0   改为
cgi.fix_pathinfo=1
重启PHP或PHP-FPM
2. 在nginx/conf/nginx.conf   找到:
 fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;  改为:
 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

重启nginx