php5.2开启缓存,[ Laravel 5.2 文档 ] 服务 -- 缓存

访问多个缓存存储

使用 Cache门面,你可以使用 store方法访问不同的缓存存储器,传入 store方法的键就是 cache 配置文件中 stores配置数组里列出的相应的存储器: $value = Cache::store('file')->get('foo');Cache::store('redis')->put('bar', 'baz', 10);

2.2 从缓存中获取数据

Cache门面的 get方法用于从缓存中获取缓存项,如果缓存项不存在,返回 null。如果需要的话你可以传递第二个参数到 get方法指定缓存项不存在时返回的自定义默认值: $value = Cache::get('key');$value = Cache::get('key', 'default');

你甚至可以传递一个闭包作为默认值,如果缓存项不存在的话闭包的结果将会被返回。传递闭包允许你可以从数据库或其它外部服务获取默认值: $value = Cache::get('key', function() { return DB::table(...)->get();});

检查缓存项是否存在

has方法用于判断缓存项是否存在: if (Cache::has('key')) { //}

数值增加/减少

increment和 decrement方法可用于调整缓存中的整型数值。这两个方法都可以接收第二个参数来指明缓存项数值增加和减少的数目: Cache::increment('key');Cache::increment('key', $amount);Cache::decrement('key');Cache::decrement('key', $amount);

获取或更新

有时候你可能想要获取缓存项,但如果请求的缓存项不存在时给它存储一个默认值。例如,你可能想要从缓存中获取所有用户,或者如果它们不存在的话,从数据库获取它们并将其添加到缓存中,你可以通过使用 Cache::remember方法实现: $value = Cache::remember('users', $minutes, function() { return DB::table('users')->get();});

如果缓存项不存在,传递给 remember方法的闭包被执行并且将结果存放到缓存中。

你还可以联合 remember和 forever方法: $value = Cache::rememberForever('users', function() { return DB::table('users')->get();});

获取并删除

如果你需要从缓存中获取缓存项然后删除,你可以使用 pull方法,和 get方法一样,如果缓存项不存在的话返回null: $value = Cache::pull('key');

2.3 存储缓存项到缓存

你可以使用 Cache门面上的 put方法在缓存中存储缓存项。当你在缓存中存储缓存项的时候,你需要指定数据被缓存的时间(分钟数): Cache::put('key', 'value', $minutes);

除了传递缓存项失效时间,你还可以传递一个代表缓存项有效时间的PHP Datetime实例: $expiresAt = Carbon::now()->addMinutes(10);Cache::put('key', 'value', $expiresAt);

add方法只会在缓存项不存在的情况下添加缓存项到缓存,如果缓存项被添加到缓存返回 true,否则,返回 false: Cache::add('key', 'value', $minutes);

forever方法用于持久化存储缓存项到缓存,这些值必须通过 forget方法手动从缓存中移除: Cache::forever('key', 'value');

2.4 从缓存中移除数据

你可以使用 Cache门面上的 forget方法从缓存中移除缓存项: Cache::forget('key');

还可以使用 flush方法清除所有缓存: Cache::flush();

清除缓存并不管什么缓存键前缀,而是从缓存系统中移除所有数据,所以在使用这个方法时如果其他应用与本应用有共享缓存时需要格外注意。

3、缓存标签

注意:缓存标签目前不支持 file或 database缓存驱动,此外,当使用多标签的缓存被设置为永久存储时,使用 memcached驱动的缓存有着最佳性能表现,因为 Memcached 会自动清除陈旧记录。

3.1 存储被打上标签的缓存项

缓存标签允许你给相关缓存项打上同一个标签以便于后续清除这些缓存值,被打上标签的缓存可以通过传递一个被排序的标签数组来访问。例如,我们可以通过以下方式在添加缓存的时候设置标签: Cache::tags(['people', 'artists'])->put('John', $john, $minutes);Cache::tags(['people', 'authors'])->put('Anne', $anne, $minutes);

你可以给多个缓存项打上相同标签,这是没有数目限制的。

3.2 访问被打上标签的缓存项

要获取被打上标签的缓存项,传递同样的有序标签数组到 tags方法: $john = Cache::tags(['people', 'artists'])->get('John');$anne = Cache::tags(['people', 'authors'])->get('Anne');

你可以同时清除被打上同一标签/标签列表的所有缓存项,例如,以下语句会移除被打上 people或 authors标签的所有缓存: Cache::tags(['people', 'authors'])->flush();

这样,上面设置的 Anne和 John缓存项都会从缓存中移除。

相反,以下语句只移除被打上 authors标签的语句,所以只有 Anne会被移除而 John不会: Cache::tags('authors')->flush();

4、添加自定义缓存驱动

要使用自定义驱动扩展 Laravel 缓存,可以使用 Cache门面提供的 extend方法,该方法用于绑定定义驱动解析器到管理器,通常,这可以在服务提供者中完成。

例如,要注册一个新的命名为“mongo”的缓存驱动: 传递给 extend方法的第一个参数是驱动名称。该值对应配置文件 config/cache.php中的 driver选项。第二个参数是返回 Illuminate\Cache\Repository实例的闭包。该闭包中被传入一个 $app实例,也就是服务容器的一个实例。

调用 Cache::extend可以在默认 App\Providers\AppServiceProvider中的 boot方法中完成,或者你也可以创建自己的服务提供者来存放该扩展——只是不要忘了在配置文件 config/app.php中注册该提供者。

要创建自定义的缓存驱动,首先需要实现 Illuminate\Contracts\Cache\Store契约,所以,我们的 MongoDB缓存实现看起来像这样子: 我们只需要使用 MongoDB连接实现每一个方法,实现完成后,我们可以完成自定义驱动注册: Cache::extend('mongo', function($app) { return Cache::repository(new MongoStore);});

扩展完成后,只需要更新配置文件 config/cache.php的 driver选项为你的扩展名称。

如果你在担心将自定义缓存驱动代码放到哪,考虑将其放到Packgist!或者,你可以在 app目录下创建一个 Extensions命名空间。然而,记住 Laravel 并没有一个严格的应用目录结构,你可以基于你的需要自由的组织目录结构。

5、缓存事件

要在每次缓存操作时执行代码,你可以监听缓存触发的事件,通常,你可以将这些缓存处理器代码放到 EventServiceProvider中: /** * The event listener mappings for the application. * * @var array */protected $listen = [ 'Illuminate\Cache\Events\CacheHit' => [ 'App\Listeners\LogCacheHit', ], 'Illuminate\Cache\Events\CacheMissed' => [ 'App\Listeners\LogCacheMissed', ], 'Illuminate\Cache\Events\KeyForgotten' => [ 'App\Listeners\LogKeyForgotten', ], 'Illuminate\Cache\Events\KeyWritten' => [ 'App\Listeners\LogKeyWritten', ],];

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值