Laravel框架怎样使用阿里云ACE缓存服务
怎样扩展 Laravel 的缓存驱动
在 Laravel 4 中使用 Cache::get($key), Cache::put($key, $value, $minutes) 这种代码时。实际上是訪问 实例化的 IlluminateCacheRepository, 所以我们通过 Cache::extend 方法扩展自己定义缓存驱动时,相同应该返回一个 IlluminateCacheRepository 对象。
Laravel 4 内置的 Memcached 缓存驱动,实现的流程是这种:
1.创建一个标准 Memcached 类的新对象
2.用上一步创建的 Memcached 对象创建一个实现了 IlluminateCacheStoreInterface 接口的 IlluminateCacheMemecachedStore 对象。
3.用上一步创建的 MemcachedStore 对象创建一个 IlluminateCacheRepository 对象。
所以我们在扩展自己定义的 Cache 驱动时,依据自己的情况。选择上面的某一个步骤自己定义,终于还是要返回 IlluminateCacheRepository 对象。
比方上一篇文章中,我就是在第一步,创建标准 Memcached 对象之后。通过 setSaslAuthData() 方法设定 OCS 须要的usernamepassword。之后第2步、第3步并不须要自己定义。
ACE 的缓存服务
阿里云 ACE 的缓存服务。跟默认的 OCS 有所不同:
1.通过 Alibaba::Cache() 方法获得 Cache 对象。
2.ACE 的 Cache 对象与标准 Memcached 对象不同,支持的方法有限。
所以,这次第一步得到的不是标准 Memcached 对象,因此就不能创建 IlluminateCacheMemcachedStore 对象。须要自己实现 IlluminateCacheStoreInterface 接口。
在控制台创建了缓存空间之后,会有唯一的“缓存空间名称”,然后通过 Alibaba::Cache('缓存空间名称') 来获得 Cache 对象。下面就是实现 ACE 缓存服务驱动的步骤:
1.为了方便改动,我在配置文件 app/config/cache.php 中添加一个名为 ace 的键,存储缓存空间名称。
2.然后创建一个 AceMemcachedStore 类,这个类实现 IlluminateCacheStoreInterface 接口。
3.最后。用 AceMemcachedStore 对象来创建 IlluminateCacheRepository 对象。
以下来看详细的代码实现:
编码实现自己定义 ACE 缓存驱动:
第一步。改动配置文件。打开 app/config/cache.php,在最后添加一行:
// 指定缓存空间名称 'ace' => 'lblog-cache',
第二步,为了方便,把自己的类文件放在 src/Ace 文件夹下。使用 Ace 作为命名空间。
1.在 app 的同级文件夹创建文件夹 src/Ace。
2.打开 composer.json 文件,改动 autoload 节,在 classmap 以下用 psr-0 或者 psr-4 来自己主动载入文件。
"autoload": { "classmap": [ // autoload class ], "psr-4": { "Ace\": "src/Ace" } },
创建 src/Ace/AceMemcachedStore.php 文件。代码例如以下:
<?php namespace Ace; use IlluminateCacheStoreInterface; use IlluminateCacheTaggableStore; class AceMemcachedStore extends TaggableStore implements StoreInterface { protected $memcached; protected $prefix; public function __construct($space, $prefix = '') { $this->memcached = Alibaba::Cache($space); $this->prefix = strlen($prefix) > 0 ? $prefix.':' : ''; } /** * Retrieve an item from the cache by key. * * @param string $key * @return mixed */ public function get($key) { $value = $this->memcached->get($this->prefix.$key); if(is_bool($value) && $value === false) { return null; } return $value; } /** * Store an item in the cache for a given number of minutes. * * @param string $key * @param mixed $value * @param int $minutes * @return boolean */ public function put($key, $value, $minutes) { return $this->memcached->set($this->prefix.$key, $value, $minutes); } /** * Increment the value of an item in the cache. * * @param string $key * @param mixed $value * @return boolean */ public function increment($key, $value = 1) { return $this->memcached->increment($this->prefix.$key, $value); } /** * Decrement the value of an item in the cache. * * @param string $key * @param mixed $value * @return boolean */ public function decrement($key, $value = 1) { return $this->memcached->decrement($this->prefix.$key, $value); } /** * Store an item in the cache indefinitely. * * @param string $key * @param mixed $value * @return boolean */ public function forever($key, $value) { return $this->memcached->set($key, $value, 0); } /** * Remove an item from the cache. * * @param string $key * @return boolean */ public function forget($key) { return $this->memcached->delete($this->prefix.$key); } /** * Remove all items from the cache. * * @return void */ public function flush() { //$this->memcached->flush(); return false; } public function getMemcached() { return $this->memcached; } /** * Get the cache key prefix. * * @return string */ public function getPrefix() { return $this->prefix; } }
这段代码比較简单,只是要特别注意一下 get($key) 方法的实现。标准 memcached 以及 ACE 的缓存对象的 get 方法都是key有效时返回相应的缓存值,否则返回false,而在 Laravel 4 中,是通过检測 get 方法返回的是否 null 来做推断,所以这里须要处理一下,返回缓存值或者null。
AceMemcachedStore类已经创建好了,接下来在 bootstrap/start.php 文件里扩展 Cache:http://www.lai18.com/content/368670.html
打开 bootstrap/start.php, 加入下面代码:
// 扩展名为 ace 的缓存驱动 Cache::extend('ace', function($app) { // 从 app/config/cache.php 文件里读取 "ace" 的值 $space = $app['config']['cache.ace']; // 从 app/config/cache.php 文件里读取 "prefix" 的值 $prefix = $app['config']['cache.prefix']; // 创建 AceAceMemcachedStore 对象 $store = new AceAceMemcachedStore($space, $prefix); // 创建并返回 IlluminateCacheRepository 对象 return new IlluminateCacheRepository($store); });
指定系统使用 'ace' 作为缓存驱动:打开 app/config/cache.php,找到 'driver' => '...' 所在行,改动为:'driver' => 'ace'.
使用和限制
通过以上操作。就能够在 Laravel 4 中调用 ACE 的缓存服务,使用上与寻常的使用方法全然一致。比方:
// 加入缓存。有效时间10分钟 Cache::put('my_key', 'my value', 10); // 读取缓存 Cache::get('my_key') // 推断缓存是否存在 Cache::has('my_key') // 数据查询缓存 $users = DB::table('users')->remember(10)->get();
可是因为 ACE 缓存对象本身的限制,仅仅能删除指定 key 的缓存对象,不能遍历、全量操作,因此 Cache::flush() 方法就不能使用。在上面的 AceMemcachedStore 对象中,flush 方法没有做不论什么操作,仅仅是返回 false.
延伸阅读
19Laravel框架学习笔记(二)项目实战之模型(Models)
25推荐几款用 Sublime Text 开发 Laravel 所用到的插件
26Laravel 4.2 中队列服务(queue)使用感受
36Laravel中使用阿里云OSS Composer包分享
37Laravel模板引擎Blade中section的一些标签的差别介绍
50PHP IDE PHPStorm配置支持友好Laravel代码提示方法
51Sublime Text 插件推荐系列 —— 用 Sublime 开发 Laravel