重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
1、eAccelerator
网站建设哪家好,找创新互联!专注于网页设计、网站建设、微信开发、重庆小程序开发、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了皇姑免费建站欢迎大家使用!
eAccelerator是一个自由开放源码PHP加速器,优化和动态内容缓存,提高了PHP脚本的缓存性能,使得PHP脚本在编译的状态下,对服务器的开销几乎完全消除。 它还有对脚本起优化作用,以加快其执行效率。使PHP程序代码执效率能提高1-10倍。从文字上可以理解为:eAccelerator是PHP加速器扩展。
2、memcached
Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提供动态、数据库驱动网站的速度。从文字上可以理解为:内存缓存扩展,并且针对于集群服务器使用较多,主要用于分布式缓存,算是数据库缓存。
3、Alternative PHP Cache(APC缓存)
Alternative PHP Cache (APC缓存)是一种对PHP有效的开放源高速缓冲储存器工具,他能够缓存Opcode(目标文件)的PHP中间码。 APC的缓存分两部分:系统缓存和用户数据缓存. 系统缓存 是自动使用的,是指APC把PHP文件源码的编译结果缓存起来,然后在再次调用时先对比时间标记。如果未过期,则使用缓存代码运行。默认缓存 3600s(一小时).但是这样仍会浪费大量CPU时间.因此可以在php.ini中设置system缓存为永不过期(apc.ttl=0).不过如果这样设置,改运PHP代码后需要restart一下您的web服务器(比如apache…).目前对APC的性能测试一般指的是这一层cache;从文字上理到:Alternative PHP Cache(APC缓存)也算是一种内存缓存扩展,算是数据库缓存扩展。
4、Xcache
是一个开源的opcode缓存器/优化器, 他能够提高服务器上的PHP性能,他通过把编译PHP后的数据缓冲到共享内存从而避免重复的编译过程, 能够直接使用缓冲区已编译的代码从而提高速度. 通常能够提高您的页面生成速率2到5倍, 降低服务器负载。 其实它与eAccelerator一样是PHP加速器扩展。
以上就是他们的作用与区别,简单一点就是:eAccelerator,xcache是PHP缓存扩展,memcached、APC缓存是数据库缓存扩展,一般两者只有要安装其中一个即可,不要贪多。另外,实际测试中发现当Cache数量超过一定阀值的时候,APC的性能不如Memcache。所以在扩展的选择上,本人一般会选择xcache+memcached这个组合。
看你的具体需求是怎样的了,
eaccelerator.,
xcache
等
还有一种就是文件缓存
这种一般是
用php自己实现的
没什么可说的一种是对
页面结果的缓存
应用服务器级别的
软件如
squid
一种是
内存级别的
一般是对
php
频繁调用的并且如果每次查询会消耗大量资源的数据
软件有
memcached
一种是
对php
程序进行优化编码的缓存
如
apache
里面的
apc
1、普遍缓存技术:
数据缓存:这里所说的数据缓存是指数据库查询PHP缓存机制,每次访问页面的时候,都会先检测相应的缓存数据是否存在,如果不存在,就连接数据库,得到数据,并把查询结果序列化后保存到文件中,以后同样的查询结果就直接从缓存表或文件中获得。
用的最广的例子看Discuz的搜索功能,把结果ID缓存到一个表中,下次搜索相同关键字时先搜索缓存表。
举个常用的方法,多表关联的时候,把附表中的内容生成数组保存到主表的一个字段中,需要的时候数组分解一下,这样的好处是只读一个表,坏处就是两个数据同步会多不少步骤,数据库永远是瓶颈,用硬盘换速度,是这个的关键点。
2、 页面缓存:
每次访问页面的时候,都会先检测相应的缓存页面文件是否存在,如果不存在,就连接数据库,得到数据,显示页面并同时生成缓存页面文件,这样下次访问的时候页面文件就发挥作用了。(模板引擎和网上常见的一些PHP缓存机制类通常有此功能)
3、 时间触发缓存:
检查文件是否存在并且时间戳小于设置的过期时间,如果文件修改的时间戳比当前时间戳减去过期时间戳大,那么就用缓存,否则更新缓存。
4、 内容触发缓存:
当插入数据或更新数据时,强制更新PHP缓存机制。
5、 静态缓存:
这里所说的静态缓存是指静态化,直接生成HTML或XML等文本文件,有更新的时候重生成一次,适合于不太变化的页面,这就不说了。
以上内容是代码级的解决方案,我直接CP别的框架,也懒得改,内容都差不多,很容易就做到,而且会几种方式一起用,但下面的内容是服务器端的缓存方案,非代码级的,要有多方的合作才能做到
6、 内存缓存:
Memcached是高性能的,分布式的内存对象PHP缓存机制系统,用于在动态应用中减少数据库负载,提升访问速度。
7、 php的缓冲器:
有eaccelerator, apc, phpa,xcache,这个这个就不说了吧,搜索一堆一堆的,自己看啦,知道有这玩意就OK
8、 MYSQL缓存:
这也算非代码级的,经典的数据库就是用的这种方式,看下面的运行时间,0.09xxx之类的
9、 基于反向代理的Web缓存:
如Nginx,SQUID,mod_proxy(apache2以上又分为mod_proxy和mod_cache)
php的缓存三种.有文件缓存,数据库缓存,memcache缓存;
memcache缓存要求对服务器支持,而且它的缓存是由期限的,一般是30天。这种缓存的效率是最高的。读存取的速度最快。
数据库缓存
和
文件缓存比较简单。适用小的项目。和php新手
5000部真的不算多了,实时查询也没问题的.按照主键查询很快的.
如果是想做缓存,可以考虑用memcache或者redis,会更快一些,因为是内存.
如果是文件的话可以将查询结果中的电影信息写到文件中,文件名是电影的id,格式是json.
本文实例讲述了php的文件缓存类。分享给大家供大家参考。具体分析如下:
缓存类是我们开发应用中会常用使用到的功能,下面就来给大家整理几个php文件缓存类了,各个文件缓存类写法不同,但在性能上会有区别,有兴趣测试的朋友可测试一下这些缓存类。
例1
复制代码
代码如下:?php
$fzz
=
new
fzz_cache;
$fzz-kk
=
$_SERVER;
//写入缓存
//$fzz-set("kk",$_SERVER,10000);
//此方法不与类属性想冲突,可以用任意缓存名;
print_r($fzz-kk);
//读取缓存
//print_r($fzz-get("kk"));
//unset($fzz-kk);
//删除缓存
//$fzz-_unset("kk");
var_dump(isset($fzz-kk));
//判断缓存是否存在
//$fzz-_isset("kk");
//$fzz-clear();
//清理过期缓存
//$fzz-clear_all();
//清理所有缓存文件
class
fzz_cache{
public
$limit_time
=
20000;
//缓存过期时间
public
$cache_dir
=
"data";
//缓存文件保存目录
//写入缓存
function
__set($key
,
$val){
$this-_set($key
,$val);
}
//第三个参数为过期时间
function
_set($key
,$val,$limit_time=null){
$limit_time
=
$limit_time
?
$limit_time
:
$this-limit_time;
$file
=
$this-cache_dir."/".$key.".cache";
$val
=
serialize($val);
@file_put_contents($file,$val)
or
$this-error(__line__,"fail
to
write
in
file");
@chmod($file,0777);
@touch($file,time()+$limit_time)
or
$this-error(__line__,"fail
to
change
time");
}
//读取缓存
function
__get($key){
return
$this-_get($key);
}
function
_get($key){
$file
=
$this-cache_dir."/".$key.".cache";
if
(@filemtime($file)=time()){
return
unserialize(file_get_contents($file));
}else{
@unlink($file)
or
$this-error(__line__,"fail
to
unlink");
return
false;
}
}
//删除缓存文件
function
__unset($key){
return
$this-_unset($key);
}
function
_unset($key){
if
(@unlink($this-cache_dir."/".$key.".cache")){
return
true;
}else{
return
false;
}
}
//检查缓存是否存在,过期则认为不存在
function
__isset($key){
return
$this-_isset($key);
}
function
_isset($key){
$file
=
$this-cache_dir."/".$key.".cache";
if
(@filemtime($file)=time()){
return
true;
}else{
@unlink($file)
;
return
false;
}
}
//清除过期缓存文件
function
clear(){
$files
=
scandir($this-cache_dir);
foreach
($files
as
$val){
if
(filemtime($this-cache_dir."/".$val)time()){
@unlink($this-cache_dir."/".$val);
}
}
}
//清除所有缓存文件
function
clear_all(){
$files
=
scandir($this-cache_dir);
foreach
($files
as
$val){
@unlink($this-cache_dir."/".$val);
}
}
function
error($msg,$debug
=
false)
{
$err
=
new
Exception($msg);
$str
=
"pre
span
style='color:red'error:/span
".print_r($err-getTrace(),1)."
/pre";
if($debug
==
true)
{
file_put_contents(date('Y-m-d
H_i_s').".log",$str);
return
$str;
}else{
die($str);
}
}
}
?