最近维护一个基于laravel的后台项目时,发现通过artisan执行任何命令都很慢,并且还会报错无法连接数据库,即使是执行php artisan optimize
这样的命令也是。这很让人疑惑,为什么执行optimize也要连接数据库并且执行效率这么慢?我在数据库报错的地方打印了调用栈,终于发现了问题。
laravel的artisan会调用Illuminate\Foundation\Console\Kernel
类来处理artisan输入的命令,该类第284行的getArtisan方法会创建一个Artisan对象,并调用Artisan对象的resolveCommands方法,参数是我们自己通过Kernel类绑定的所有Command类名,在resolveCommands方法中laravel会将我们绑定的所有Command类实例化,而项目中很多Command类的构造方法里有如下写法:
class Example extends Command {
public function __construct() {