
在常驻内存PHP应用中,Composer自动加载需在服务启动时一次性引入,避免重复定义或旧代码残留。
在基于 Swoole 或 RoadRunner 的常驻内存 PHP 应用中,使用 Composer 时需要特别注意自动加载机制和类的生命周期管理。由于这类应用是常驻内存的,传统的每次请求都重新加载类和依赖的方式不再适用,稍有不慎就会导致类未找到、重复定义或旧代码残留等问题。
Composer 的自动加载机制(特别是 classmap 和 psr-4)在 CLI 或 FPM 环境下每次请求都会重新初始化。但在 Swoole 或 RoadRunner 中,主进程只启动一次,Composer autoloader 也只会注册一次。如果在运行时动态添加命名空间或修改文件结构,不会被自动感知。
常见问题包括:
确保在服务启动的最开始阶段就加载 Composer autoloader,并且只加载一次。
错误做法:在每个请求中包含 vendor/autoload.php,这可能导致重复引入或内存泄漏。
在入口文件(如 server.php)中一次性引入:
on('request', function ($req, $resp) {
// 业务逻辑,不要再次 require autoload
});
$server->start();
loader 映射不要在请求处理过程中调用 ClassLoader::addPsr4() 或 addClassMap()。这些操作会污染全局状态,且在多协程环境下可能引发冲突。
如果你需要动态加载模块,建议:
在开发环境中,可以结合文件监控工具实现平滑重启:
--enable-reload 和 inotify 监控文件变化,触发工作进程重启rr 的 watch 模式自动重载 worker注意:重载会重建整个进程,autoloader 也会重新初始化,因此能正确加载新代码。
生产环境不建议开启热重载,应通过发布流程重启服务以保证一致性。
常驻内存应用对性能敏感,建议优化 Composer autoloader:
composer dump-autoload --optimize 生成更高效的 classmap基本上就这些。关键是把 Composer autoloader 当作启动时的一次性基础设施,而不是每次请求都依赖的组件。只要在进程启动时正确加载,后续请求就能稳定访问所有类。