Laravel 是当前最成熟、文档最全、社区最强的 PHP 框架之一,但启动开销大、内存占用高、对新手不友好,轻量场景易“杀鸡用牛刀”。
PHP 后端开发中,Laravel 并非“唯一选择”,而是当前生态里最成熟、文档最全、社区支持最强的框架之一;但它也自带明显代价——启动开销大、内存占用高、对新手不友好,尤其在轻量 API 或 CLI 工具场景下容易“杀鸡用牛刀”。
artisan 命令在 Docker 容器里常报 Class 'App\Console\Commands\XXX' not found
这不是类没写,而是自动加载未刷新。Docker 构建时若把 vendor/ 和 composer autoload 缓存一并打包进去,后续修改命令类文件不会触发重生成。
Dockerfile 中删掉 vendor/,改用 RUN composer install --no-dev --optimize-autoloader 保证每次构建都重生成 vendor/autoload.php
php artisan clear-compiled && php artisan optimize:clear(Laravel 9+ 用 optimize:clear 替代)APP_ENV=production 下直接改 app/Console/Commands/ 然后跑命令——生产模式会跳过某些自动发现逻辑Queue::dispatch() 在 Supervisor 下不消费?查这三处队列“发出去了但没执行”,大概率不是代码问题,而是环境链路断在中间。
QUEUE_CONNECTION 配置必须和 supervisor.conf 中启动的 php artisan queue:work 命令所指定的连接一致,例如:配置是 redis,但 supervisor 启动时写了 --queue=emails 却没配 redis.queue 值,默认会卡住autostart=true 和 autorestart=true 要开启,且检查 ps aux | grep queue:work 确认进程确实在跑,不是启动即崩(常见于 .env 未加载或 Redis 连接超时)database 驱动,确认 jobs 表引擎是 InnoDB(MyISAM 不支持行锁,会导致并发消费异常)当项目只需 REST API、无 Eloquent 关系映射、无 Blade 渲染、无复杂中间件栈时,Laravel 的抽象层反而拖慢开发与部署。
Slim 路由极简,$app->get('/users', Handler::class); 就完事,无服务提供者注册负担Doctrine\DBAL 比 Laravel 的 DB facade 更透明——SQL 写在哪、参数绑定怎么走、事务怎么开,全部可控,调试时不会被 Query Builder 包裹层干扰League\Container 是 PSR-11 兼容容器,比 Laravel 的 IoC 更轻、无魔法方法调用,适合需要明确依赖注入路径的团队migrate:fresh --seed 一键重置,没有 tinker 交互终端,也没有 php artisan serve 开箱即用的 dev server框架选型真正难的不是功能多寡,而是边界感——Laravel 擅长“你只管写业务,其余我兜底”,但兜底的代价是它必须预设所有可能路径;一旦你的业务绕开了它的默认路径(比如用 Swoole 做长连接、用 ClickHouse 替代 MySQL、用 Protobuf 替代 JSON),那些“省下的代码”就会变成“排查三天的黑盒”。