实现PHP页面静态化_PHP教程
-
原创
-
2016-07-20 11:17:55
582浏览
php
//首先查看缓存文件
if(file_exists("static.html")){
//缓存时间为3分钟
if(time()-filemtime("static.html")";
echo file_get_contents("static.html");
$end_time = microtime();
echo "静态文件使用时间:".($end_time-$start_time);
exit;
}
}
//如果是首次访问,或者是上次缓存的时间超过3分钟,则从数据库中读取数据
$host = "127.0.0.1";
$user = "root";
$password = "123456";
//记录开始时间
$start_time = microtime();
mysql_connect($host,$user,$password);
mysql_select_db("mydb");
mysql_query("set names utf8");
$sql = "SELECT name,address,email FROM users";
$resource = mysql_query($sql);
echo "我是从数据库中读取的数据:
";
ob_start();//打开输出缓冲
echo "
姓名 | 地址 | Email |
";
//输出取得的信息
while($userInfo = mysql_fetch_assoc($resource)){
echo "";
echo "".$userInfo['name']." | ";
echo "".$userInfo['address']." | ";
echo "".$userInfo['email']." | ";
echo "
";
}
$end_time=microtime();
$str=ob_get_contents();//获取缓冲区的内容
ob_end_flush();
echo "从数据库读数据的时间:".($end_time-$start_time);
file_put_contents("static.html",$str);
?>
users表中有三条记录,使用的是apache服务。测试结果如下:
从数据库中读数据其平均执行时间为:0.0008041s左右
直接读缓存文件期平均执行时间为:0.0000475
数据库中的记录只有三条,SQL也是简单的单表查询,当表的中记录很多时,或者是多表查询其执行的时间将会更长。缓存虽然能够减少访问数据库的次数,加速响应时间,但缓存并不适合所有的页面。有些页面可能每次访问时其页面的显示的内容就会发生变化,这样的页面显然不能使用缓存。对于那些变化很少的页面才比较适合使用缓存。
http://www.bkjia.com/PHPjc/371932.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/371932.htmlTechArticle? php //首先查看缓存文件if(file_exists(static.html)){//缓存时间为3分钟if(time()-filemtime(static.html)60*3){//将静态文件内容返回给客户端$start_time = mi...
声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。