首页 > 文章列表 > Ubuntu Nginx部署PHP项目404错误:如何正确配置Nginx和PHP-FPM?

Ubuntu Nginx部署PHP项目404错误:如何正确配置Nginx和PHP-FPM?

500 2025-03-24

Ubuntu Nginx部署PHP项目404错误:如何正确配置Nginx和PHP-FPM?

在Ubuntu系统上使用Nginx部署PHP项目时,404错误是常见的难题。本文将分析此问题,并提供有效的解决方案。

问题场景: 用户在Ubuntu系统上使用Nginx(8088端口)部署PHP项目,所有请求均返回404错误。即使修改了Nginx配置文件,问题依然存在。

问题根源及解决方案:

问题主要在于Nginx与PHP-FPM的配置不匹配。虽然完整的配置文件未提供,但关键部分已能指出问题所在。核心问题在于Nginx的location块配置,它负责将请求路由到正确的处理程序。错误的配置导致Nginx无法将PHP请求正确传递给PHP-FPM。

以下是一个正确的Nginx配置文件示例:

server {
    listen 8088; # 监听端口,根据实际情况调整
    server_name www.h5fiction1.com;
    root /path/to/your/project/public; # 请替换为你的项目public目录的绝对路径

    location / {
        try_files $uri $uri/ /index.php?$args; # 尝试寻找文件或目录,否则转发到index.php
    }

    location ~ .php$ {
        include snippets/fastcgi-php.conf; # 包含fastcgi-php配置片段
        fastcgi_pass unix:/run/php/php8.1-fpm.sock; # 或你的php-fpm socket路径
    }
}

关键解释:

  • listen 8088;: 监听端口,请根据你的实际情况修改。
  • root /path/to/your/project/public;: 至关重要! 请将/path/to/your/project/public替换为你的PHP项目public目录的绝对路径。这是Nginx服务器查找文件的基础路径。
  • try_files $uri $uri/ /index.php?$args;: 这是一个更简洁高效的配置,它首先尝试查找$uri指定的文件或目录。如果找不到,则尝试查找$uri/(添加斜杠,用于目录)。如果仍然找不到,则将请求转发到index.php,并保留原始请求参数$args
  • include snippets/fastcgi-php.conf;: 包含预定义的FastCGI参数配置,简化配置过程。这个文件通常位于Nginx的安装目录下。
  • fastcgi_pass unix:/run/php/php8.1-fpm.sock;: 指定PHP-FPM的socket路径。 请根据你的PHP-FPM安装和配置修改此路径。 你可能需要使用tcp连接,例如fastcgi_pass 127.0.0.1:9000;,但unix socket通常效率更高。

其他注意事项:

  • 确保PHP-FPM服务已启动。 使用systemctl status php8.1-fpm (或你的PHP版本) 检查状态。
  • 检查root指令指向的路径是否正确且可访问。 使用ls -l /path/to/your/project/public 验证路径是否存在。
  • 检查PHP-FPM的配置文件,确保socket路径与Nginx配置一致。
  • 搜索关键词“nginx php-fpm 配置”或“tp6 nginx fastcgi”可以找到更多相关信息。

此配置假设你的PHP-FPM使用的是Unix socket。如果使用的是TCP连接,请相应修改fastcgi_pass指令。 仔细检查所有路径和参数,确保它们与你的项目结构和PHP-FPM配置完全匹配。 如果问题仍然存在,请提供你的完整Nginx和PHP-FPM配置文件以便进一步诊断。

来源:1740954138