這篇文章主要介紹了Laravel中擴(kuò)展Memcached緩存驅(qū)動(dòng)實(shí)現(xiàn)使用阿里云OCS緩存,本文擴(kuò)展了一個(gè)支持SASL 認(rèn)證模式的Memcached緩存驅(qū)動(dòng),需要的朋友可以參考下
Laravel 是我最近用得非常多而且越用就越喜歡的一款PHP框架,由于沒(méi)有向下兼容的歷史包袱,完全面向?qū)ο蟮娘L(fēng)格,借助 Facades 優(yōu)雅的IoC Container 實(shí)現(xiàn),采用 Composer 進(jìn)行包管理,可以方便地引入和使用開(kāi)源社區(qū)里的優(yōu)秀組件……總而言之,這是一款真正讓你能夠 "code happy" 的“巨匠級(jí)PHP開(kāi)發(fā)框架”。
在嘗試把自己的 Laravel App 部署到阿里云的時(shí)候,遇到了一個(gè)問(wèn)題: Laravel 支持 Memcached 緩存,阿里云的 OCS 也是基于 Memcached 的緩存,但是阿里云 OCS 采用 SASL 認(rèn)證,而 Laravel 的 Memcached 驅(qū)動(dòng)并沒(méi)有實(shí)現(xiàn)相關(guān)的方法,即使在服務(wù)器上編譯PHP Memcached 的時(shí)候啟用了 SASL 認(rèn)證選項(xiàng),也沒(méi)辦法設(shè)定用戶名和密碼。
在 Laravel 中,解決這樣的問(wèn)題,有很多方法。我選擇了最快捷最省事的方法:擴(kuò)展 Laravel 自己的 Memcached 驅(qū)動(dòng),通過(guò) Memcached 對(duì)象自身的 setSaslAuthData 方法,指定用戶名和密碼。
背景知識(shí)
這是利用了 Illuminate\Cache\CacheManager 的 extend 方法(繼承自Illuminate\Support\Manager)。先看一下這個(gè)方法的定義:
代碼如下:
/**
* Register a custom driver creator Closure.
*
* @param string $driver
* @param Closure $callback
* @return \Illuminate\Support\Manager|static
*/
public function extend($driver, Closure $callback){}
這個(gè)方法接收兩個(gè)參數(shù),第一個(gè)是代表你自定義的驅(qū)動(dòng)名稱的字符串,第二個(gè)是一個(gè)閉包回調(diào)函數(shù),這個(gè)函數(shù)就是當(dāng)調(diào)用你的自定義驅(qū)動(dòng)時(shí)要執(zhí)行的方法。通過(guò)閱讀 Illuminate\Cache\CacheManager 的源代碼,我們可以發(fā)現(xiàn)創(chuàng)建驅(qū)動(dòng)的函數(shù)要返回一個(gè) Illuminate\Cache\Repository 的實(shí)例,Illuminate\Cache\Repository 的構(gòu)造函數(shù)如下:
復(fù)制代碼 代碼如下:
/**
* Create a new cache repository instance.
*
* @param \Illuminate\Cache\StoreInterface $store
*/
public function __construct(StoreInterface $store)
{
$this->store = $store;
}
它需要一個(gè)實(shí)現(xiàn)了 Illuminate\Cache\StoreInterface 接口的對(duì)象,這個(gè)接口中定義了 Cache 對(duì)象能夠執(zhí)行的方法。由于我計(jì)劃是擴(kuò)展原有的 Memcached 緩存驅(qū)動(dòng),在 Illuminate\Cache\CacheManager 的源代碼中,可以看到 Laravel 是這樣創(chuàng)建 Memcached 驅(qū)動(dòng)的:
代碼如下:
/**
* Create an instance of the Memcached cache driver.
*
* @return \Illuminate\Cache\MemcachedStore
*/
protected function createMemcachedDriver()
{
$servers = $this->app['config']['cache.memcached'];
$memcached = $this->app['memcached.connector']->connect($servers);
return $this->repository(new MemcachedStore($memcached, $this->getPrefix()));
}
它先從配置文件中讀取你定義的 Memcached 服務(wù)器,然后創(chuàng)建一個(gè) Memcached 對(duì)象(通過(guò) Illuminate\Cache\MemcachedConnector 實(shí)現(xiàn),實(shí)際上就是創(chuàng)建一個(gè)標(biāo)準(zhǔn)的 Memcached 對(duì)象,然后調(diào)用 Memcached 的 addServer 方法來(lái)指定要連接的服務(wù)器,然后返回實(shí)例化的 Memcached 對(duì)象。)
擴(kuò)展自己的緩存驅(qū)動(dòng)
了解了上述的背景知識(shí)之后,就可以來(lái)擴(kuò)展自己的緩存驅(qū)動(dòng)了。思路如下:
1.在 app/config/cache.php 文件中,增加三個(gè)配置項(xiàng),用來(lái)設(shè)定“是否使用sasl認(rèn)證”,“sasl認(rèn)證賬戶”,“sasl認(rèn)證密碼”。
2.在 bootstrap/start.php 文件中,調(diào)用 Cache::extend 方法擴(kuò)展驅(qū)動(dòng)。
3.在 app/config/cache.php 文件中,修改 driver 配置項(xiàng),指定系統(tǒng)使用自己擴(kuò)展的驅(qū)動(dòng)。
增加配置項(xiàng)
首先,打開(kāi) app/config/cache.php 文件,找到:
代碼如下:
'memcached' => array(
array('host' => '127.0.0.1', 'port' => 11211, 'weight' => 100),
),
修改為:
代碼如下:
'memcached' => array(
array('host' => '127.0.0.1', 'port' => 11211, 'weight' => 100),
),
'memcached_sasl' => 'true', // 啟用sasl認(rèn)證
'memcached_user' => 'your ocs username', // 你的 OCS 用戶名
'memcached_pass' => 'your ocs password', // 你的 OCS 密碼
擴(kuò)展驅(qū)動(dòng)
然后,打開(kāi) bootstrap/start.php 文件,在最后一行 return $app; 前面插入代碼:
代碼如下:
// 基于系統(tǒng)自己的 Memcached 緩存驅(qū)動(dòng),擴(kuò)展一個(gè)名為 saslMemcached 的緩存驅(qū)動(dòng)
Cache::extend('saslMemcached', function($app){
// 從配置文件中讀取 Memcached 服務(wù)器配置
$servers = $app['config']['cache.memcached'];
// 利用 Illuminate\Cache\MemcachedConnector 類來(lái)創(chuàng)建新的 Memcached 對(duì)象
$memcached = $app['memcached.connector']->connect($servers);
// 如果服務(wù)器上的 PHP Memcached 擴(kuò)展支持 SASL 認(rèn)證
if(ini_get('memcached.use_sasl')){
// 從配置文件中讀取 sasl 認(rèn)證用戶名
$user = $app['config']['cache.memcached_user'];
// 從配置文件中讀取 sasl 認(rèn)證密碼
$pass = $app['config']['cache.memcached_pass'];
// 禁用 Memcached 壓縮 (阿里云的文檔里這樣做了……)
$memcached->setOption(Memcached::OPT_COMPRESSION, false);
// 指定 Memcached 使用 binary protocol ( sasl 認(rèn)證要求 )
$memcached->setOption(Memcached::OPT_BINARY_PROTOCOL, true);
// 指定用于 sasl 認(rèn)證的賬號(hào)密碼
$memcached->setSaslAuthData($user, $pass);
}
// 從配置文件中讀取緩存前綴
$prefix = $app['config']['cache.prefix'];
// 創(chuàng)建 MemcachedStore 對(duì)象
$store = new \Illuminate\Cache\MemcachedStore($memcached, $prefix);
// 創(chuàng)建 Repository 對(duì)象,并返回
return new \Illuminate\Cache\Repository($store);
});
修改配置,使用自己擴(kuò)展的緩存驅(qū)動(dòng)
打開(kāi) app/config/cache.php 文件,找到:
代碼如下:
"driver" => "file", // 默認(rèn)是使用文件緩存
修改為:
代碼如下:
"driver" => "saslMemcached", // 剛才擴(kuò)展實(shí)現(xiàn)的驅(qū)動(dòng)名稱
現(xiàn)在,你就可以在你的 阿里云 ECS 服務(wù)器上, 讓 Laravel 使用 阿里云 OCS 緩存服務(wù)了。
更多信息請(qǐng)查看IT技術(shù)專欄