搜索
首页php教程php手册Laravel中扩展Memcached缓存驱动实现使用阿里云OCS缓存,laravelmemcached

Laravel中扩展Memcached缓存驱动实现使用阿里云OCS缓存,laravelmemcached

Laravel 是我最近用得非常多而且越用就越喜欢的一款PHP框架,由于没有向下兼容的历史包袱,完全面向对象的风格,借助 Facades 优雅的IoC Container 实现,采用 Composer 进行包管理,可以方便地引入和使用开源社区里的优秀组件……总而言之,这是一款真正让你能够 "code happy" 的“巨匠级PHP开发框架”。

在尝试把自己的 Laravel App 部署到阿里云的时候,遇到了一个问题: Laravel 支持 Memcached 缓存,阿里云的 OCS 也是基于 Memcached 的缓存,但是阿里云 OCS 采用 SASL 认证,而 Laravel 的 Memcached 驱动并没有实现相关的方法,即使在服务器上编译PHP Memcached 的时候启用了 SASL 认证选项,也没办法设定用户名和密码。

在 Laravel 中,解决这样的问题,有很多方法。我选择了最快捷最省事的方法:扩展 Laravel 自己的 Memcached 驱动,通过 Memcached 对象自身的 setSaslAuthData 方法,指定用户名和密码。

背景知识

这是利用了 Illuminate\Cache\CacheManager 的 extend 方法(继承自Illuminate\Support\Manager)。先看一下这个方法的定义:

复制代码 代码如下:


/**
 * Register a custom driver creator Closure.
 *
 * @param  string   $driver
 * @param  Closure  $callback
 * @return \Illuminate\Support\Manager|static
 */
public function extend($driver, Closure $callback){}


这个方法接收两个参数,第一个是代表你自定义的驱动名称的字符串,第二个是一个闭包回调函数,这个函数就是当调用你的自定义驱动时要执行的方法。通过阅读 Illuminate\Cache\CacheManager 的源代码,我们可以发现创建驱动的函数要返回一个 Illuminate\Cache\Repository 的实例,Illuminate\Cache\Repository 的构造函数如下:

复制代码 代码如下:


/**
 * Create a new cache repository instance.
 *
 * @param  \Illuminate\Cache\StoreInterface  $store
 */
public function __construct(StoreInterface $store)
{
    $this->store = $store;
}

它需要一个实现了 Illuminate\Cache\StoreInterface 接口的对象,这个接口中定义了 Cache 对象能够执行的方法。由于我计划是扩展原有的 Memcached 缓存驱动,在 Illuminate\Cache\CacheManager 的源代码中,可以看到 Laravel 是这样创建 Memcached 驱动的:

复制代码 代码如下:


/**
 * 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 服务器,然后创建一个 Memcached 对象(通过 Illuminate\Cache\MemcachedConnector 实现,实际上就是创建一个标准的 Memcached 对象,然后调用 Memcached 的 addServer 方法来指定要连接的服务器,然后返回实例化的 Memcached 对象。)

扩展自己的缓存驱动

了解了上述的背景知识之后,就可以来扩展自己的缓存驱动了。思路如下:

1.在 app/config/cache.php 文件中,增加三个配置项,用来设定“是否使用sasl认证”,“sasl认证账户”,“sasl认证密码”。
2.在 bootstrap/start.php 文件中,调用 Cache::extend 方法扩展驱动。
3.在 app/config/cache.php 文件中,修改 driver 配置项,指定系统使用自己扩展的驱动。

增加配置项

首先,打开 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认证
    'memcached_user' => 'your ocs username', // 你的 OCS 用户名
    'memcached_pass' => 'your ocs password', // 你的 OCS 密码

扩展驱动

然后,打开 bootstrap/start.php 文件,在最后一行 return $app; 前面插入代码:

复制代码 代码如下:


// 基于系统自己的 Memcached 缓存驱动,扩展一个名为 saslMemcached 的缓存驱动
Cache::extend('saslMemcached', function($app){
    // 从配置文件中读取 Memcached 服务器配置
    $servers = $app['config']['cache.memcached'];
    
    // 利用 Illuminate\Cache\MemcachedConnector 类来创建新的 Memcached 对象
    $memcached = $app['memcached.connector']->connect($servers);
 
    // 如果服务器上的 PHP Memcached 扩展支持 SASL 认证
    if(ini_get('memcached.use_sasl')){
        
        // 从配置文件中读取 sasl 认证用户名
        $user = $app['config']['cache.memcached_user'];
 
        // 从配置文件中读取 sasl 认证密码
        $pass = $app['config']['cache.memcached_pass'];
        
        // 禁用 Memcached 压缩 (阿里云的文档里这样做了……)
        $memcached->setOption(Memcached::OPT_COMPRESSION, false);
 
        // 指定 Memcached 使用 binary protocol ( sasl 认证要求 )
        $memcached->setOption(Memcached::OPT_BINARY_PROTOCOL, true);
 
        // 指定用于 sasl 认证的账号密码
        $memcached->setSaslAuthData($user, $pass);
    }
 
    // 从配置文件中读取缓存前缀
    $prefix = $app['config']['cache.prefix'];
 
    // 创建 MemcachedStore 对象
    $store = new \Illuminate\Cache\MemcachedStore($memcached, $prefix);
    
    // 创建 Repository 对象,并返回
    return new \Illuminate\Cache\Repository($store);
});

修改配置,使用自己扩展的缓存驱动

打开 app/config/cache.php 文件,找到:

复制代码 代码如下:


"driver" => "file", // 默认是使用文件缓存


修改为:

复制代码 代码如下:


"driver" => "saslMemcached", // 刚才扩展实现的驱动名称


现在,你就可以在你的 阿里云 ECS 服务器上, 让 Laravel 使用 阿里云 OCS 缓存服务了。(前提是你的 PHP 支持 Memcached 扩展,并且启用了 SASL 认证,参考:http://help.aliyun.com/doc/view/13553932.html
声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它们
1 个月前By尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境