顾名思义,是Nginx用来处理FastCGI的模块。FastCGI是什么?这个之后再讲,能够说的是如今LNMP架构里面,PHP通常是以PHP-CGI的形式在运行,它就是一种FastCGI,咱们在进程中看到的PHP-FPM是PHP-CGI的管理调度器。php
由于LNMP不像LAMP,且早期Nginx不支持path_info,致使网上有大量旧版本的Nginx教程干扰视线。html
为了更加清晰准确使用LNMP,估须要深刻了解一下整个ngx_http_fastcgi_module。nginx
做用域:location, if in locationgit
设置FastCGI服务,其值能够是一个域名、IP地址:端口、或者是一个Unix的Socket文件。github
同时,它也只支持一个FastCGI服务集群。正则表达式
# TCP形式传递 fastcgi_pass localhost:9000; # Socket形式传递 fastcgi_pass unix:/tmp/fastcgi.socket; # 传递给集群 upstream cloud { server cgi_1.cloud.com; server cgi_2.cloud.com; } fastcgi_pass cloud;
upstream集群定义不在本次讨论范围,更多玩法请参考官方文档。安全
做用域:http, server, location架构
设置一个传递给FastCGI服务的参数,能够是文本或者是变量。socket
# 例如在接入层Nginx上面传递以下5个参数 fastcgi_param REMOTE_ADDR $remote_addr; fastcgi_param REMOTE_PORT $remote_port; fastcgi_param SERVER_ADDR $server_addr; fastcgi_param SERVER_PORT $server_port; fastcgi_param SERVER_NAME $server_name; # 那么在FastCGI上面,例如PHP-CGI上面就能够经过$_SERVER这个超全局变量获取。 $_SERVER['REMOTE_ADDR'] $_SERVER['REMOTE_PORT'] $_SERVER['SERVER_ADDR'] $_SERVER['SERVER_PORT'] $_SERVER['SERVER_NAME']
可传递的参数,遵循CGI/1.1规范定义。unix
能够从Github上面看到Nginx在3年前实现FastCGI的参数传递后,基本就没变过了。
做用域:http, server, location
当请求以/
结尾的时候,会将请求传递给所设置的index.php文件处理。
fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /home/www/scripts/php$fastcgi_script_name;
做用域:location
Nginx默认获取不到PATH_INFO的值,得经过fastcgi_split_path_info指定定义的正则表达式来给$fastcgi_path_info
赋值。
其正则表达式必需要有两个捕获。
$fastcgi_script_name
变量。$fastcgi_path_info
变量。例子:
location ~ ^(.+\.php)(.*)$ { fastcgi_split_path_info ^(.+\.php)(.*)$; fastcgi_param SCRIPT_FILENAME /path/to/php$fastcgi_script_name; fastcgi_param PATH_INFO $fastcgi_path_info; }
原始请求是 /show.php/article/0001
。
经过分割,FastCGI获得的结果是:
/path/to/php/show.php
/article/0001
Nginx在0.7.31之前是没有fastcgi_split_path_info这个指令的,而0.7.x这个版本一直存活了好多年,后面才高歌猛进,致使网上存在大量旧版本经过正则本身设置PATH_INFO的方法。
为何老是踩坑?由于咱们都会经过重写来隐藏index.php文件,而ThinkPHP的教程,默认教的是旧版Nginx写法,且URL_MODE必须设置为3也说得很隐晦(URL_MODE默认为0)。
例如ThinkPHP的说明有一段旧版的Nginx设置指引。
location / { // …..省略部分代码 if (!-e $request_filename) { rewrite ^(.*)$ /index.php?s=$1 last; break; } }
该规则是经过将请求rewrite给/index.php?s=
来实现的,其ThinkPHP的URL_MODE配置必须为3,也就是兼容模式。
若是使用本文中的传递PATH_INFO方式,且隐藏index.php,则ThinkPHP的URL_MODE须要改成2。
若是使用本文中的传递PATH_INFO方式,但不隐藏index.php,则ThinkPHP的URL_MODE改成1。
cgi.fix_pathinfo
cgi.fix_pathinfo参数,藏在PHP-FPM的php.ini配置里面,其默认值为1。
这里存在一个安全风险,我也不通,详情不表,看鸟哥的文章:http://www.laruence.com/2010/05/20/1495.html
习惯性将其设置为0便可。