源码解读 Laravel php artisan config:cache

JellyBool

JellyBool

再来一篇源码解读系列,其实包含本篇 config:cache 源码解读在内,这三篇的源码解读都是跟线上环境部署 Laravel 项目有关,因为我们通常会使用这三个 artisan 命令来提高项目的执行效率。所以,我们进入正题:php artisan config:cache 源码解读

源码在哪

首先,我们还是可以使用编辑器的搜索功能搜 ConfigCacheCommand,这样就可以直接打开 config:cache 命令的源代码了,位于 Illuminate\Foundation\Console\ConfigCacheCommand 中,关键的代码还是位于 fire() 方法中:

public function fire(){


   $this->call('config:clear');

   // other codes

}

首先,在执行 php artisan config:cache 之前,我们需要将之前缓存过的配置文件清除,就是通过 $this->call('config:clear'); 这一行代码来实现的。

那,config:clear 的源码在哪呢?

这个命令的源码位于 Illuminate\Foundation\Console\ConfigClearCommand 中,你依然是可以在编辑器搜 ConfigClearCommand,然后定位到这里的 fire() 方法里面:

public function fire(){

   $this->files->delete($this->laravel->getCachedConfigPath());


   $this->info('Configuration cache cleared!');

}

你看,这里的代码就非常简单,主要就是删除原来缓存的配置文件,这个缓存的配置文件通过getCachedConfigPath() 获取到,这个 getCachedConfigPath()Illuminate\Foundation\Application 中:

public function getCachedConfigPath(){

   return $this->bootstrapPath().'/cache/config.php';

}

熟悉了吧,它也是放到 bootstrap/cache/ 目录下面的,命名为 config.php

那么以上就删除完缓存的配置了,然后我们再次回到 config:cache 中。既然旧的缓存已经删除,那么我们就需要生成新的缓存文件了,所以再次聚焦 ConfigCacheCommandfire() 方法:

public function fire(){


   $config = $this->getFreshConfiguration();


   $this->files->put(

            $this->laravel->getCachedConfigPath(), '<?php return '.var_export($config, true).';'.PHP_EOL

        );

}

首先 通过 getFreshConfiguration() 获取所有新的配置信息,这部分的代码逻辑就在 ConfigCacheCommand 中:

protected function getFreshConfiguration(){

    $app = require $this->laravel->bootstrapPath().'/app.php';

    $app->make(ConsoleKernelContract::class)->bootstrap();

    return $app['config']->all();

}

这三行代码很简单,就是生成了一个 Laravel 的 Application 实例,然后通过 $app['config']->all() 获取所有的配置信息。

获取配置信息之后,就把新的配置信息写入缓存中,上面 ConfigCacheCommand fire() 方法的这一行实现:

$this->files->put(

    $this->laravel->getCachedConfigPath(), 

    '<?php return '.var_export($config, true).';'.PHP_EOL

    );

getCachedConfigPath() 已经很熟悉啦,在讨论 cache:clear 时我们就知道,其实就是获取到 bootstrap/cache/config.php 文件,然后写入配置的内容 var_export($config, true),所以最后缓存的配置文件大概的内容是这样的:

最后

有了缓存的配置文件,下次访问 Laravel 项目的时候就是直接读取缓存的配置了,而不用再次去计算和获取新的配置,这样来说,速度依然会快那么一点点。

本文由 JellyBool 创作, 转载和引用遵循 署名-非商业性使用 2.5 中国大陆 进行许可。

共有 0 条评论