首頁 後端開發 php教程 能php不回缓存行吗?多重实现

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

Jun 13, 2016 am 10:37 AM
gt html lt nbsp quot

会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本身的缓存机制。其实还有好多技术,需要融会贯通。

 

顶一个,亲们。。。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1657
14
CakePHP 教程
1415
52
Laravel 教程
1309
25
PHP教程
1257
29
C# 教程
1229
24
HTML 中的表格邊框 HTML 中的表格邊框 Sep 04, 2024 pm 04:49 PM

HTML 表格邊框指南。在這裡,我們以 HTML 中的表格邊框為例,討論定義表格邊框的多種方法。

HTML 中的巢狀表 HTML 中的巢狀表 Sep 04, 2024 pm 04:49 PM

這是 HTML 中巢狀表的指南。這裡我們討論如何在表中建立表格以及對應的範例。

HTML 左邊距 HTML 左邊距 Sep 04, 2024 pm 04:48 PM

HTML 左邊距指南。在這裡,我們討論 HTML margin-left 的簡要概述及其範例及其程式碼實作。

HTML 表格佈局 HTML 表格佈局 Sep 04, 2024 pm 04:54 PM

HTML 表格佈局指南。在這裡,我們詳細討論 HTML 表格佈局的值以及範例和輸出。

HTML 輸入佔位符 HTML 輸入佔位符 Sep 04, 2024 pm 04:54 PM

HTML 輸入佔位符指南。在這裡,我們討論 HTML 輸入佔位符的範例以及程式碼和輸出。

HTML 有序列表 HTML 有序列表 Sep 04, 2024 pm 04:43 PM

HTML 有序列表指南。在這裡我們也分別討論了 HTML 有序列表和類型的介紹以及它們的範例

HTML onclick 按鈕 HTML onclick 按鈕 Sep 04, 2024 pm 04:49 PM

HTML onclick 按鈕指南。這裡我們分別討論它們的介紹、工作原理、範例以及各個事件中的onclick事件。

您如何在PHP中解析和處理HTML/XML? 您如何在PHP中解析和處理HTML/XML? Feb 07, 2025 am 11:57 AM

本教程演示瞭如何使用PHP有效地處理XML文檔。 XML(可擴展的標記語言)是一種用於人類可讀性和機器解析的多功能文本標記語言。它通常用於數據存儲

See all articles