Heim  >  Artikel  >  Backend-Entwicklung  >  能php不回缓存行吗?多重实现

能php不回缓存行吗?多重实现

WBOY
WBOYOriginal
2016-06-13 10:37:45688Durchsuche

会php不回缓存行吗?多重实现

1、普遍缓存技术:

  数据缓存:这里所说的数据缓存是指数据库查询PHP缓存机制,每次访问页面的时候,都会先检测相应的缓存数据是否存在,如果不存在,就连接数据库,得到数据,并把查询结果序列化后保存到文件中,以后同样的查询结果就直接从缓存表或文件中获得。

  用的最广的例子看Discuz的搜索功能,把结果ID缓存到一个表中,下次搜索相同关键字时先搜索缓存表。

  举个常用的方法,多表关联的时候,把附表中的内容生成数组保存到主表的一个字段中,需要的时候数组分解一下,这样的好处是只读一个表,坏处就是两个数据同步会多不少步骤,数据库永远是瓶颈,用硬盘换速度,是这个的关键点。

2、 页面缓存:

  每次访问页面的时候,都会先检测相应的缓存页面文件是否存在,如果不存在,就连接数据库,得到数据,显示页面并同时生成缓存页面文件,这样下次访问的时候页面文件就发挥作用了。(模板引擎和网上常见的一些PHP缓存机制类通常有此功能)

3、 时间触发缓存:

   检查文件是否存在并且时间戳小于设置的过期时间,如果文件修改的时间戳比当前时间戳减去过期时间戳大,那么就用缓存,否则更新缓存。

4、 内容触发缓存:

   当插入数据或更新数据时,强制更新PHP缓存机制。

5、 静态缓存:

  这里所说的静态缓存是指静态化,直接生成HTML或XML等文本文件,有更新的时候重生成一次,适合于不太变化的页面,这就不说了。


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)

10、 DNS轮询:  
  BIND是一款开放源码的DNS服务器软件,这个要说起来就大了,自己搜索去,大家知道有这个东西就行了。
  我知道的有chinacache等大站就是这样做的,说简单点就是多服务器啦,把同一个页面或文件缓存到不同的服务器上,按南北自动解析到相关的服务器中

 

对于第五种方法,案例如下:

 

代码 :

1.       创建测试数据库

create database lxr;

use lxr;

create table news(

id int unsigned primary key auto_increment, /*新闻id*/

title varchar(128) not null,/*新闻标题*/

content varchar(256) not null,/*新闻内容*/

filename varchar(32)) /*记录静态页面名字*/engine=MyISAM

2.       测试数据

insert into news (title,content) values('hello1','北京你好');

insert into news (title,content) values('hello2','四川你好');

 

news_list.php 代码如下:

 

              //新闻列表

              $conn=mysql_connect("localhost","root","root");

              if(!$conn){

                     die("连接失败");

              }

 

              mysql_select_db("lxr",$conn);

 

              //mysql_query("set names utf8");

 

              $sql="select * from news";

              $res=mysql_query($sql);

 

 

              header("content-type:text/html;charset=utf-8");

              echo "

新闻列表";

              echo "添加新闻


";

              echo "

";

              echo "

";

              while($row=mysql_fetch_assoc($res)){

                     echo "

";

              }

              echo "

id 标题 查看详情
{$row['id']} {$row['title']} 查看详情
";

 

              //关闭资源

              mysql_free_result($res);

              mysql_close($conn);

 

?>

show_news.php

 

 

       //接受id

       $id=@$_GET['id'];

 

              //看看如何使用html静态页面

              //思路,看看html页面是否有,如果有,直接访问,没有就创建

              //构建一个文件名.

              $html_filename="news_id".$id.".html";

              //filemtime()=>获取文件的最后修改时间

              //filemtime($html_filename)+30>time()表示静态文件,

              if(file_exists($html_filename)&& filemtime($html_filename)+30>time()){

                    

                     //直接访问html页面(html页面的内容 echo 浏览器)

                     echo file_get_contents($html_filename);

                     exit;

              }

 

              $conn=mysql_connect("localhost","root","root");

             

              if(!$conn){

                     die("连接失败");

              }

 

              mysql_select_db("lxr",$conn);

             

              $sql="select * from news where id=$id";

              $res=mysql_query($sql);

              //开启ob缓存

              ob_start();

              if($row=mysql_fetch_assoc($res)){

 

                     header("content-type:text/html;charset=utf-8");

                     echo "

";

                     echo "

";

                     echo "

";

                     echo "

";

                     echo "

新闻详细内容
{$row['title']}
{$row['content']}
";

              }else{

                     echo "没有结果";

              }

 

              $html_content=ob_get_contents();

              $my_hader="";

              //ob->$html_filename (必要时,需要考虑路径)

              file_put_contents($html_filename,$my_hader.$html_content);

 

              mysql_free_result($res);

              mysql_close($conn);

 

 

?>

用法:将利用上面的sql脚本,创建好数据库 和表。在将上面两个php文件放入你的开发环境中。运行第一个news_list.php 即可生成静态页面。

      本人总结如下:其实 就俩函数 ob_start(); ob_get_contents(); 将你想要缓存的部分放在这两个函数之间,缓存的内容就是ob_get_contents 函数的返回值。

   并用file_put_contents($html_filename,$my_hader.$html_content); 将缓存的页面写入文件中,

       if(file_exists($html_filename)&& filemtime($html_filename)+30>time()){

                    

                     //直接访问html页面(html页面的内容 echo 浏览器)

                     echo file_get_contents($html_filename);

                     exit;

              }

读的时候先看该文件是否存在并设置一个延时时间,如果存在就直接echo出来,若不存在,则操作数据库并写入该文件。

上面讲的是php本身的缓存机制。其实还有好多技术,需要融会贯通。

 

顶一个,亲们。。。

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn