|
对于大型门户网站,有很多人在浏览,评论或者贡献。数据库服务器能够处理如此大的负载吗?Apache服务器能否处理如此多的请求?答案可能是不能,除非你实现缓存(caching)。
Memcached
在前一篇文章中,我们已经了解了Memcache是一个高性能的分布式的内存对象缓存系统,如果你想了解更多也可以去其官网看看。 Memcached官方主页.
PHP Memcache
这篇文章主要是介绍怎样通过PHP的Memcache模块来实现Memcached。虽然这篇文章是针对于PHP语言,但是这里的概念也能够应用于其他的语言。在开始实战之前,首先确认Memcached已经安装在你的机器上,如果还没有安装请查看 windows7下为PHP5.3安装Memcached。下面是详细介绍:
第1步:建立连接
这一步很直接,如果你不能连接到你的缓存server,那就不能缓存。
$memcache = new Memcache;
$memcache->connect("localhost", 11211);
第2步: 缓存(Cache)一些东西
这一步只需注意,变量名要唯一,过期时间是以秒为单位
$myValue = "hello world!";
$memcache->set("Hello World", $myValue, false, 60*60*24);
第3步: 从缓存中得到值
$myValue = $memcache->get("Hello World");
echo $myValue;
第4步: 一个完整的实例
web应用中使用缓存的基本流程如下:
(1)需要查找的项目(item)是否在缓存中.
(2)如果存在,得到缓存中的item并赋给变量.
(3)如果不存在,从数据库中查找该item.
(4)存储item以备后用.
完整测试代码:(你可以将以下代码保存为php文件后运行)
<?php
$memcache = new Memcache;
$memcache->connect('localhost', 11211) or die ("Could not connect");
$arrayVals = $memcache->get("My Identifier");
if(!$arrayVals){
/*
$query = "select * from myTable";
$result = mysql_query($query);
while($row = mysql_fetch_array($result)){
$arrayVals[] = $row;
}
*/
//模拟查询结果集
$arrayVals = array(
array("time"=>time(),"item2"=>"value2"),
array("count"=>1000,"enable"=>true)
);
//缓存将会保存10秒,你可以不断的刷新该页面。
//time的值将会10秒钟更新一次
$memcache->set("My Identifier",$arrayVals,false,10);
}
foreach($arrayVals as $val) {
print_r($val);
}
?>
如果你运行了上面的代码,细心的你会发现,当你第一次访问该页面时,数据将会从数据库中读取(这里我们数据是自己构造的,并没有查数据库),然后接下来的10秒钟,数据是从缓存服务器中读取的。当然这里我只是为了方便测试代码,快速验证我们的想法是否正确,所以设置缓存时间只有10秒钟。实际应用中,应该要根据情况来处理。 |
|
|