news 2026/4/29 2:18:49

运维工程师技术之nginx搭配php

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
运维工程师技术之nginx搭配php

出现“File not found.”的核心原因是fastcgi_param SCRIPT_FILENAME配置错误,导致PHP-FPM找不到对应的PHP文件。以下是具体分析和修复方案:

一、直接原因:SCRIPT_FILENAME路径错误

你配置中的这一行:

fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;

是Nginx默认的错误写法——/scripts是一个不存在的目录,而你的PHP文件实际在/app/code/zbx目录下。

当Nginx把请求转发给PHP-FPM时,会告诉它“要执行的文件在/scripts/xxx.php”,但这个路径根本不存在,所以PHP-FPM返回“File not found.”。

二、修复步骤

1. 修正SCRIPT_FILENAME参数

/scripts改为$document_root(自动关联当前配置的root目录),同时补充roottry_files指令(确保路径正确):

location ~ \.php$ { root /app/code/zbx; # 必须和上面location /的root一致,指定PHP文件所在目录 try_files $uri =404; # 先检查文件是否存在,不存在直接返回404(避免无效请求) fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; # 关键修正:用$document_root获取当前root目录,正确指向PHP文件 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; }
2. 补充index的优先级(可选但建议)

index中的index.php放到前面,优先解析PHP索引页:

location / { root /app/code/zbx; index index.php index.htm; # 把index.php放前面 }

三、修复后的完整配置

server { listen 80; server_name localhost www.zbx888.com; location / { root /app/code/zbx; index index.php index.htm; # 优先解析PHP索引页 try_files $uri $uri/ /index.php$is_args$args; # 处理PHP项目路由 } error_page 500 502 503 504 /50x.html; location = /50x.html { root /usr/share/nginx/html; } # 修复后的PHP解析块 location ~ \.php$ { root /app/code/zbx; # 和项目根目录一致 try_files $uri =404; # 检查文件是否存在 fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } # 禁止访问隐藏文件(提升安全性) location ~ /\.ht { deny all; } }

四、验证与生效

  1. 检查配置语法

    nginx -t

    输出“test is successful”说明语法正确。

  2. 重启Nginx

    systemctl restart nginx
  3. 确认PHP文件存在
    确保/app/code/zbx目录下有index.php(或你访问的PHP文件):

    ls-l /app/code/zbx/index.php

五、额外排查(若仍报错)

如果修复后还是“File not found.”,检查:

  • PHP-FPM的用户权限:PHP-FPM默认以apachenginx用户运行,需确保该用户能读取/app/code/zbx下的文件:
    chown-R nginx:nginx /app/code/zbxchmod-R755/app/code/zbx
  • SELinux限制:临时关闭SELinux测试(生产环境需配置规则):
    setenforce0

修复后,浏览器访问www.zbx888.com就能正常解析PHP文件了。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/28 19:39:54

攻克Sidekick本地AI助手的7大技术壁垒

攻克Sidekick本地AI助手的7大技术壁垒 【免费下载链接】Sidekick A native macOS app that allows users to chat with a local LLM that can respond with information from files, folders and websites on your Mac without installing any other software. 项目地址: htt…

作者头像 李华
网站建设 2026/4/28 22:57:04

腾讯混元4B开源:轻量级大模型如何重塑AI部署格局

腾讯混元4B开源:轻量级大模型如何重塑AI部署格局 【免费下载链接】Hunyuan-4B-Pretrain 腾讯开源混元大语言模型Hunyuan-4B预训练版本,具备高效部署与强大性能。支持256K超长上下文理解,融合快慢思维双推理模式,在数学、编程、科学…

作者头像 李华
网站建设 2026/4/23 17:13:38

Hocuspocus 完整指南:构建实时协作应用的终极解决方案

Hocuspocus 完整指南:构建实时协作应用的终极解决方案 【免费下载链接】hocuspocus The Y.js WebSocket backend 项目地址: https://gitcode.com/gh_mirrors/ho/hocuspocus Hocuspocus 是一个基于 Y.js 的即插即用协作后端,专门为开发者提供简单高…

作者头像 李华
网站建设 2026/4/20 17:14:34

VideoSrt:3分钟快速制作专业视频字幕的终极指南

VideoSrt:3分钟快速制作专业视频字幕的终极指南 【免费下载链接】video-srt-windows 这是一个可以识别视频语音自动生成字幕SRT文件的开源 Windows-GUI 软件工具。 项目地址: https://gitcode.com/gh_mirrors/vi/video-srt-windows 还在为视频字幕制作而烦恼…

作者头像 李华