Laravel框架中实现使用阿里云ACE缓存服务

  这篇文章主要介绍了Laravel框架中实现使用阿里云ACE缓存服务,本文扩展了一个ACE缓存驱动,以便使用阿里云ACE缓存服务,需要的朋友可以参考下

  之前我写了一篇在 Laravel 4 框架中使用阿里云 OCS 缓存的文章,介绍了如何通过扩展 Laravel 4 来支持需要 SASL 认证的阿里云 OCS 缓存服务。有网友问我,ACE 的缓存怎么在 Laravel 4 中使用。我本来觉得应该可以完全用相同的办法,后来自己尝试的时候才发现,ACE 的缓存差别非常大。所以再写一篇,介绍一下如何在 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 需要的用户名密码。之后第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 文件,代码如下:

  代码如下:

  

  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:

  打开 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.

时间: 2024-10-21 21:27:52

Laravel框架中实现使用阿里云ACE缓存服务的相关文章

Laravel框架中实现使用阿里云ACE缓存服务_php技巧

之前我写了一篇在 Laravel 4 框架中使用阿里云 OCS 缓存的文章,介绍了如何通过扩展 Laravel 4 来支持需要 SASL 认证的阿里云 OCS 缓存服务.有网友问我,ACE 的缓存怎么在 Laravel 4 中使用.我本来觉得应该可以完全用相同的办法,后来自己尝试的时候才发现,ACE 的缓存差别非常大.所以再写一篇,介绍一下如何在 Laravel 框架中使用阿里云 ACE 的缓存服务. 如何扩展 Laravel 的缓存驱动 在 Laravel 4 中使用 Cache::get($

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

这篇文章主要介绍了Laravel中扩展Memcached缓存驱动实现使用阿里云OCS缓存,本文扩展了一个支持SASL 认证模式的Memcached缓存驱动,需要的朋友可以参考下 Laravel 是我最近用得非常多而且越用就越喜欢的一款PHP框架,由于没有向下兼容的历史包袱,完全面向对象的风格,借助 Facades 优雅的IoC Container 实现,采用 Composer 进行包管理,可以方便地引入和使用开源社区里的优秀组件--总而言之,这是一款真正让你能够 "code happy"

Laravel中扩展Memcached缓存驱动实现使用阿里云OCS缓存_php技巧

Laravel 是我最近用得非常多而且越用就越喜欢的一款PHP框架,由于没有向下兼容的历史包袱,完全面向对象的风格,借助 Facades 优雅的IoC Container 实现,采用 Composer 进行包管理,可以方便地引入和使用开源社区里的优秀组件--总而言之,这是一款真正让你能够 "code happy" 的"巨匠级PHP开发框架". 在尝试把自己的 Laravel App 部署到阿里云的时候,遇到了一个问题: Laravel 支持 Memcached 缓存

使用阿里云容器监控服务与第三方监控框架集成搭建自己的容器看板

一.概述 阿里云容器监控服务日前正式上线,容器监控服务提供了非常简单快速地与第三方开源监控方案集成的能力.本篇文章就带领大家一起试用阿里云容器监控服务,并使用目前比较流行的第三方开源监控框架做集成,搭建自己的监控看板. 二.操作 1. 编排模板与注意事项 version: '2' services: #定义influxdb influxdb: image: tutum/influxdb:0.9 ports: - "8083:8083" #暴露web界面端口 - "8086:8

一分钟了解阿里云产品:阿里云ACE之初体验

阿里云ACE开始公测了,ACE(Aliyun Cloud Engine) 是一款弹性.分布式的应用托管环境,支持Java.php多种语言环境.帮助开发者快速开发和部署服务端应用程序,并且简化了系统维护工作.搭载了丰富的分布式扩展服务,为应用程序提供强大助力.     ACE(Aliyun Cloud Engine)目前最大的优点就是免费,预计以后也会照着SAE JAE等同类服务提供低廉的收费政策,怀着激动的心情赶紧试用了一下.   可是试用就得做点东西啊,就把之前的一个想法实现了:做一个到期域名

阿里云ACE的使用和评测及安装PHP程序的方法

阿里云推出ACE已经很长的一段时间了,但是最近的阿里云ACE开始公测了,现在的阿里云使用很是方便,而且在公测期间免费. 阿里云ACE是阿里云的一个一键建站工具,使用阿里云一键建站工具可以快速的安装wordpress博客程序和phpwind论坛程序,很方便,当然,它也支持支持PHP,Java,NODE.JS等语言来编写web应用,使用非常的方便. 新版阿里云开通PHP空间 ACE开通地址http://www.aliyun.com/act/aliyun/2015/win/ace.html?spm=5

如何接入阿里云短信服务 (完整指南)

目录 一.注册并实名认证 二.开通短信服务 三.获取AccessKey 四.设置短信内容 五.配置短信接口 六.发送短信 七.常见问题FAQ 一.注册并实名认证 使用阿里云短信服务,用户需要先在阿里云注册,并完成个人/企业实名认证. 注意:要发送营销短信的用户,必须完成企业实名认证 1.1 注册阿里云:点此注册  1.2 实名认证:点此认证  1.3 绑定企业支付宝: 点击绑定企业支付宝   二.开通短信服务 2.1.开通短信服务:点击开通短信服务 2.2 子账号页面:点击查看子账号页面 2.3

阿里云资源编排服务 Java SDK使用入门

阿里云资源编排服务 Java SDK使用入门 安装依赖 添加Maven库 <repositories> <repository> <id>sonatype-nexus-staging</id> <name>Sonatype Nexus Staging</name> <url>https://oss.sonatype.org/service/local/staging/deploy/maven2/</url> &

通过命令行工具使用阿里云资源编排服务

资源编排ROS 是一种简单易用的云计算资源管理和自动化运维服务.用户通过模板描述多个云计算资源的依赖关系.配置等,并自动完成所有资源的创建和配置,以达到自动化部署.运维等目的. 了解更多 通过命令行工具使用阿里云资源编排服务 资源编排服务(ROS)支持用户通过模板文件定义所需的云资源,描述资源间的依赖关系和配置详情,并自动完成资源的创建和配置,以达到自动化部署.运维等目的. 作为一种自动化运维工具,阿里云ROS屏蔽了底层资源操作的复杂性,使得对基础设施资源的管理通过简单的代码就可以实现. 命令行