PHP配置Nginx运行PHP教程_PHP与Nginx配合部署方法

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 脚本。先检查是否已装:

  • Ubuntu/Debian:sudo apt install php-fpm
  • CentOS/RHEL:sudo yum install php-fpmdnf install php-fpm

安装后启动并设为开机自启:

  • 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 配置)。

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 foundSCRIPT_FILENAME 路径不对,确认 $document_root 和实际文件位置一致
  • 空白页或直接下载 .php 文件 → location 正则没匹配上,确认 URL 确实以 .php 结尾,且该 location 块在 server 块内、未被其他规则覆盖

基本上就这些。配一次记牢逻辑,后面换版本或换机器照着改就行。