新手学PHP架构要先懂什么_基础概念与学习路径【教程】

16次阅读

php架构本质是围绕运行时、请求生命周期与组件协作的实践模式,需先理解SAPI层触发机制、自动加载原理、会话存储机制及环境链路问题,而非直接学习抽象概念。

新手学PHP架构要先懂什么_基础概念与学习路径【教程】

PHP 架构不是一门独立语言,而是一套围绕 PHP 运行时、请求生命周期和组件协作方式形成的实践模式。新手直接啃“架构”只会卡在抽象概念里,真正要先搞懂的是:谁在调用 php-fpm$_GET 从哪来又到哪去?require_once 和自动加载之间差了哪一层?

http 请求进来后,PHP 真正执行的第一行代码在哪?

不是你写的 index.php,而是 Web 服务器(如 nginx)把请求转给 php-fpm 后,php-fpm worker 进程载入并执行的入口脚本。这个过程没有“全局主函数”,只有「SAPI 层触发」——比如 apache2handlerfpm-fcgi SAPI 初始化 PHP 执行环境,然后才轮到你的代码。

  • phpinfo() 输出里的 Server API 行,就是当前实际起作用的 SAPI 类型
  • Nginx 配置中 fastcgi_pass 127.0.0.1:9000 对应的就是 php-fpm 的监听地址,断开它,所有 PHP 页面立刻 502
  • CLI 模式下运行 php script.php 走的是 cli SAPI,不经过 Web 服务器,也没有 $_SERVER['REQUEST_URI'] 这类变量

为什么 autoload 不是“自动包含文件”,而是靠 spl_autoload_register() 注册回调?

PHP 解析器本身不识别命名空间与文件路径映射关系。new appControllersUserControllerclass not found,不是因为没写 require,而是没人告诉 PHP “这个类名应该去哪个路径找”。

  • composer 自动生成的 vendor/autoload.php 本质就是一 spl_autoload_register() 回调,每个回调负责一段命名空间前缀
  • 手写自动加载时,若在回调里用 include 而非 require,类文件不存在会导致静默失败,后续报错会更难定位
  • PSR-4 标准规定 AppFooBar 映射到 src/Foo/Bar.php,但这个规则不是 PHP 内置的,是 autoloader 实现者自己解析字符串实现的

$_session 数据到底存在哪?为什么刷新页面有时就丢了?

默认存在服务器本地文件系统(/tmp 下的 sess_* 文件),由 session.save_handler = files 控制。丢失通常不是代码问题,而是环境链路断裂:

立即学习PHP免费学习笔记(深入)”;

  • 浏览器未携带 PHPSESSID cookie(可能被同站策略拦截,或前端 js 创建了新上下文)
  • session_start() 前有输出(哪怕一个空格),导致 HTTP Header 无法写入 Set-Cookie
  • 开发时多个标签页共用会话,一个调用 session_destroy(),其他页立即失效
  • 生产环境改用 redis 存储时,session.save_path 必须设为 tcp://127.0.0.1:6379?database=1 这类 DSN 格式,不能只写 IP
ini_set('session.save_handler', 'redis'); ini_set('session.save_path', 'tcp://127.0.0.1:6379?database=1'); session_start(); // 必须在修改 ini 设置后、任何输出前调用

架构感是在反复调试 502 Bad gateway、查 php-fpm.logchild process exited on signal 11、翻 strace -p 看 PHP 进程卡在哪个系统调用之后,慢慢长出来的。别从“微服务”“DDD 分层”开始,先确认你能用 curl -v 看清一次请求完整流经 Nginx → php-fpm → index.php → pdomysql 的每一步响应头和状态码。

text=ZqhQzanResources