PHP在Nginx上运行需配置PHP-FPM与Nginx协同:先安装并启动PHP-FPM,再在Nginx中配置正确的fastcgi_pass、include fastcgi_params及SCRIPT_FILENAME,最后通过phpinfo()验证。

PHP 要在 Nginx 上正常运行,关键不是装了 PHP 就行,而是让 Nginx 知道“哪些请求该交给 PHP 处理”,并确保 PHP-FPM 服务在后台正确响应。下面分几步说清楚怎么配。
确认 PHP-FPM 已安装并运行
Nginx 本身不解析 PHP,必须靠 PHP-FPM(FastCGI Process Manager)来执行 PHP 脚本。先检查是否已装:
安装后启动并设为开机自启:
- sudo systemctl start php-fpm
- sudo systemctl enable php-fpm
默认监听地址通常是 127.0.0.1:9000 或 /run/php/php*-fpm.sock(具体路径看 /etc/php/*/fpm/pool.d/www.conf 中的 listen 配置)。
立即学习“PHP免费学习笔记(深入)”;
Nginx 配置支持 PHP 的 location 块
在站点配置文件(如 /etc/nginx/sites-available/your-site 或 /usr/local/nginx/conf/conf.d/default.conf)中,添加或修改 location ~ \.php$ 区块:
location ~ \.php$ {
include fastcgi_params;
fastcgi_pass 127.0.0.1:9000; # 或 unix:/run/php/php8.1-fpm.sock;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
}注意三点:
- fastcgi_pass 必须和 PHP-FPM 实际监听地址一致(IP:端口 或 Unix socket)
- include fastcgi_params 提供基础变量,别漏掉
- SCRIPT_FILENAME 务必写对,否则会报 “File not found”,常见错误是路径拼错
测试 PHP 是否真正生效
在网站根目录(如 /var/www/html)新建一个 info.php:
然后重启服务:
- sudo systemctl reload nginx
- 如果改过 PHP-FPM 配置,也 reload 它:sudo systemctl reload php-fpm
浏览器访问 http://你的IP/info.php,能看到 PHP 信息页,说明配置成功。
常见问题快速排查
如果打不开或报错,优先查这几项:
- 502 Bad Gateway → Nginx 找不到 PHP-FPM,检查 fastcgi_pass 地址 + PHP-FPM 是否运行(sudo systemctl status php-fpm)
- File not found → SCRIPT_FILENAME 路径不对,确认 $document_root 和实际文件位置一致
- 空白页或直接下载 .php 文件 → location 正则没匹配上,确认 URL 确实以 .php 结尾,且该 location 块在 server 块内、未被其他规则覆盖
基本上就这些。配一次记牢逻辑,后面换版本或换机器照着改就行。











