玩玩Memcache缓存组件For PHP

前言
几乎每次面试都会有一个很基本的问题,实习生的基本问题,那就是

如何优化数据库或减少数据库的压力?
(1) 合理增加索引
(2) 优化SQL语句
(3) 主从配置(读写分离)
(4) ...
注意:除了上面的几点外,我们还可以使用缓存机制,比如Redis、Memcache等等


Memcache简介
Memcache是danga.com的一个项目,最早是为 LiveJournal 服务的,目前全世界不少人使用这个缓存项目来构建自己大负载的网站,来分担数据库的压力。Memcache依赖libevent事件协程组件,存储机制为键值对的形式,数据存储的方式为内存式。它可以应对任意多个连接,使用非阻塞的网络IO。由于它的工作机制是在内存中开辟一块空间,然后建立一个HashTable,Memcached管理这些HashTable,所以速度非常快。


Memcache的安装

# memcache依赖libevent
sudo apt-get install libevent-2.0-5 memcached

在何处使用memcache
第一:数据库查询(select)使用
第二:在控制回话(sesion)使用


PHP的Memcache客户端所有方法总结

Memcache::add – 添加一个值,如果已经存在,则返回false 
Memcache::addServer – 添加一个可供使用的服务器地址 
Memcache::close – 关闭一个Memcache对象 
Memcache::connect – 创建一个Memcache对象 
Memcache::memcache_debug – 控制调试功能 
Memcache::decrement – 对保存的某个key中的值进行减法操作 
Memcache::delete – 删除一个key值 
Memcache::flush – 清除所有缓存的数据 
Memcache::get – 获取一个key值 
Memcache::getExtendedStats – 获取进程池中所有进程的运行系统统计 
Memcache::getServerStatus – 获取运行服务器的参数 
Memcache::getStats – 返回服务器的一些运行统计信息 
Memcache::getVersion – 返回运行的Memcache的版本信息 
Memcache::increment – 对保存的某个key中的值进行加法操作 
Memcache::pconnect – 创建一个Memcache的持久连接对象 
Memcache::replace -对一个已有的key进行覆写操作 
Memcache::set – 添加一个值,如果已经存在,则覆写 
Memcache::setCompressThreshold – 对大于某一大小的数据进行压缩 
Memcache::setServerParams – 在运行时修改服务器的参数 

使用缓存的机制
对于基本的缓存机制很简单,如图所示

玩玩Memcache缓存组件For PHP_第1张图片
image.png

代码展示

connect("localhost", 11211);

/** - core 获取数据 **/

//先从缓存读取数据
$data = $memcache->get("data");
//倘若缓存没有数据,那么我们需要从数据库读取
if(!$data){
    echo "data come from db
"; $db = new mysqli("localhost","samego","samego","demo"); $sql = "SELECT * FROM `demo`"; $result = $db->query($sql); $data = array(); while ($row = $result->fetch_assoc()){ $data[] = $row; } $result->free(); $db->close(); //既然从数据库获取了数据,那就保存到内存 $memcache->set("data",$data,MEMCACHE_COMPRESSED,3600); } print_r($data); // close $memcache->close();

你可能感兴趣的:(玩玩Memcache缓存组件For PHP)