ThinkPHP使用Memcached缓存数据

ThinkPHP默认使用文件缓存数据,支持Memcache等其他缓存方式,有两个PHP扩展:Memcache和Memcached,Memcahe官方有说明,主要说一下Memcached。

相对于PHP Memcache,php Memcached是基于原生的c的libmemcached的扩展,更加完善,建议替换为php memcached。

版本3.2.2开始内置了Memcached驱动(ThinkPHP/Library/Think/Cache/Driver/Memcached.class.php),但是文档中并没有说明用法,通过查看源码配置并测试成功。

有个bug至今未修复,就是过期时间为0的问题,理论上应该是永久缓存,但是驱动中未做处理,会马上过期,set方法修改如下

    public function set($name, $value, $expire = null) {
        N(‘cache_write‘,1);
        if(is_null($expire)) {
            $expire  =  $this->options[‘expire‘];
        }
        $name   =   $this->options[‘prefix‘].$name;
        if (empty($expire))
            $time = 0;
        else
            $time = time() + $expire;
        if($this->handler->set($name, $value, $time)) {
            if($this->options[‘length‘]>0) {
                // 记录缓存队列
                $this->queue($name);
            }
            return true;
        }
        return false;
    }

在配置文件config.php中添加

//缓存配置
    ‘DATA_CACHE_TYPE‘ => ‘Memcached‘,
    ‘MEMCACHED_SERVER‘ => array(
        array(‘127.0.0.1‘, 11211, 0)
    ),

驱动中是调用Memcached::addServers(array)可以添加多个缓存服务器

还有一个配置项是 MEMCACHED_LIB,调用的是 Memcached::setOptions(array)

具体选项可参考PHP中文手册

时间: 2024-12-13 16:44:46

ThinkPHP使用Memcached缓存数据的相关文章

清除memcached缓存数据的方式

第一.连接:telnet 127.0.0.1 11211 第二.按回车键 第三.flush_all 后回车 控制台显示OK,表示操作成功 说明: 1.清空所有键值 flush_all 注:flush并不会将items删除,只是将所有的items标记为expired,因此这时memcache依旧占用所有内存. 2.退出 quit 清除memcached缓存数据的方式

ThinkPHP 3.2.3 数据缓存与静态缓存

ThinkPHP 3.2.3 中手册中数据缓存的地址是:http://www.kancloud.cn/manual/thinkphp/1835 静态缓存的地址是:http://www.kancloud.cn/manual/thinkphp/1839 数据缓存 使用 S 方法进行数据缓存,缓存文件默认的方式是文件缓存(DATA_CACHE_TYPE = File),文件缓存默认的保存路径是 ./Application/Runtime/Temp 当使用默认的缓存方式时,不需要在配置文件中进行配置,直

MyBatis与Memcached集成后缓存数据不一致问题

缓存数据生成到memcache的过程如下: 一.查询数据: 1.根据执行的sql语句转换为缓存的sqlKey值2.根据sqlKey值查询memcache的缓存数据3.如果查询到缓存数据返回缓存数据4.如果查询不到缓存数据则执行sql查询5.根据执行的sql语句转换为缓存的sqlKey值6.根据 mapper namespace 生成 groupKey7.sql查询结果放入缓存,数据结构[sqlKey(sql语句转换为的缓存sqlKey值),object(sql查询结果)]8.根据groupKey

thinkphp的静态缓存,数据缓存,快速缓存,查询缓存

// 静态缓存 // 'HTML_PATH' 缓存目录,这是个常量不是配置项,在入口文件中定义 // 'HTML_CACHE_ON'     =>    true, // 开启静态缓存 'HTML_CACHE_TIME'   =>    3600, // 全局静态缓存有效期(秒) 'HTML_FILE_SUFFIX'  =>    '.html', // 设置静态缓存文件后缀 'HTML_CACHE_RULES'  =>     array( // 定义静态缓存规则 // 定义整个

ThinkPHP使用memcache缓存服务器

(1)Thinkphp的默认缓存方式是以File方式,在/Runtime/Temp 下生成了好多缓存文件. 服务器装了memcached后想给更改成memecache方式 在Conf/config.php 中添加 'DATA_CACHE_TYPE' => 'Memcache', 'MEMCACHE_HOST'   => 'tcp://127.0.0.1:11211', 'DATA_CACHE_TIME' => '3600', (2)thinkphp官方下载扩展ThinkPHP_Exten

Memcached 缓存个体,对象,泛型,表

转自 :http://www.cnblogs.com/panshengqiang/p/3605599.html 下面是两位大牛关于Memcached的介绍:大家可以看看 http://zhoufoxcn.blog.51cto.com/792419/528212 http://leepiao.blog.163.com/blog/static/48503130201104103344851/ 如下是我的总结: Memcached是一个命令行窗口程序,可以在命令行窗口中启动也可以封装在系统服务中启动.

应对Memcached缓存失效,导致高并发查询DB的几种思路

原文地址: http://blog.csdn.net/hengyunabc/article/details/20735701 当Memcached缓存失效时,容易出现高并发的查询DB,导致DB压力骤然上升. 这篇blog主要是探讨如何在缓存将要失效时,及时地更新缓存,而不是如何在缓存失效之后,如何防止高并发的DB查询. 个人认为,当缓存将要失效时,及时地把新的数据刷到memcached里,这个是解决缓存失效瞬间高并发查DB的最好方法.那么如何及时地知道缓存将要失效? 解决这个问题有几种思路: 比

Memcached缓存框架

开发基于BS模式的程序,都有报表模块,那么如何开发报表模块. 1.定时发布报表数据到指定的临时表(可能是定时任务) 2.用户通过HTTP请求后台,访问临时表,查询报表数据 3.增加memcached缓存,再次访问是直接访问缓存. memcached原理:基于内存的缓存分布式系统,基于libevent(epoll)或者的事件机制,保证非阻塞的网络IO,内部数据结构采取链表,Hash索引.内存管理图:分配的内存分割成各种尺寸的块(chunk), 并把尺寸相同的块分成组(chunk的集合) memca

第二百九十三,Memcached缓存

Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度.Memcached基于一个存储键/值对的hashmap.其守护进程(daemon )是用C写的,但是客户端可以用任何语言来编写,并通过memcached协议与守护进程通信. Memcached安装和基本使用 Window下memcached安装与测试步骤 下载好软件包memcached-1.4.20版本 安装步骤1.