zblogphp主题开发之缓存调用,可减少大量的数据库请求,加快网站打开速度!
大概的讲一下,有关zblogphp主题开发时候用到的缓存调用,可以减少大量的数据库请求,加快网站打开速度。
我们都知道,网站一般由首页、列表页、文章页,这三块组成,有些网站首页和列表页是一样的,常见于博客主题,当然也有首页和列表页不一样的,像cms主题,企业主题等,当然网站不仅仅像我说的只有这三种页面,再多页面的也都有,但是我们也知道,一个页面里面内容很多,都是需要我们在模板里面写函数,从数据库里面调用出来,才可以正常使用的,当一个页面比较复杂时候(常见于cms主题或企业主题),页面很多地方都进行各种数据库查询的时候,就会造成网站访问速度变慢。具体的,如果使用zblogphp版本的朋友们,可以鼠标右键点击页面,查看源代码,拖到最下面,可以看到一条类似这样的东西:
<!--13.94 ms , 13 query , -848kb memory , 0 error-->
这个是我小锋博客的,因为使用的是php7.1,所以在页面大小上面显示有误,变负数了,主要是看前面的ms和query。(当然,如果大家看我的博客,可能看到的是接近0的ms,和0 query,这是因为我使用了别的缓存插件,这个后面再说。)下面看看具体操作流程。
实现方法
一般很多地方的调用数据,都不是动态调用,数据如果有改变,那一般是由于新建了文章导致的,所以我们可以在编辑文章,提交保存的时候调用我们所需的数据,然后往某个地方生成一个静态文件,这样的话,我们在模板里面直接调用这个静态文件即可,这样就不会再次请求数据库了。(这点类似动态页面与静态页面,动态页面在每次访问的时候,都会带着参数去请求数据库,得到内容后返回再给大家展示,而静态,是已经请求数据库获得内容后缓存下来的静态文件,直接访问即可,这样相对来说速度就会快很多。)
具体操作
以缓存前6篇最近更新的文章作为例子,在主题目录下的include.php文件中,加入下面这个函数代码:
function 主题ID_RecentUpdates(&$article){ global $zbp; $RecentUpdates = $zbp->GetArticleList('*', array(array('=', 'log_Type', 0), array('=', 'log_Status', 0)), array('log_PostTime' => 'DESC'), 6, null,false); $str = ''; foreach ($RecentUpdates as $UpdatesArticle){ $str .= '<li><a href="'.$UpdatesArticle->Url.'" title="'.$UpdatesArticle->Title.'" >'.$UpdatesArticle->Title.'</a></li>'; } @file_put_contents($zbp->usersdir . 'theme/'.$zbp->theme.'/include/RecentUpdates.php', $str); }
然后在主题目录下的include.php文件中找到ActivePlugin_主题ID这个函数,在里面给上面的函数挂载接口:
Add_Filter_Plugin('Filter_Plugin_PostArticle_Succeed','主题ID_RecentUpdates');
这样就算完成了。
这时候随便打开一篇文章,什么都不用修改,直接点提交保存,这样会在主题目录下的include文件夹里面,生成一个名为RecentUpdates.php的文件。
在模板文件中,我们可以直接用{module:RecentUpdates}标签来调用RecentUpdates.php文件里面的内容,注意咯,文件名跟标签里面的名字是相同的。
注:更多zblogphp系统接口可以到这里查找:https://wiki.zblogcn.com/doku.php?id=zblogphp:development:plugin:interfaces
其他说明
上面例子中,“主题ID”根据自己实际去修改,不要直接复制粘贴过去使用,不然必定报错。
通过上面的操作,我们在提交保存文章的时候,就可以获取6篇最近更新的文章,并且保存在主题目录/include文件夹里面,这样的话,我们在模板里面无需再次查询数据库来获取内容,而是直接调用这个文件即可,这样就达到了一个缓存的目的。
关于缓存插件,之前zblog应用中心是有一个缓存插件的,作者是鸟儿,但是由于某些问题,插件被下架了,所以现在搜索不出来。。
另外,我并不是大牛,上面很多东西我是个人理解后说出来的,有些地方说得不够专业或者有误,大神轻喷,欢迎点评。
学习了。点我名称,提交网站,免费。
博主的网站确实很快 我用的zb刚装时挺快 然后就慢的不想管理了
啊。。。看到这个。。。我想说,对于普通的数据库查询,其实这样。。。并不会节省资源多少。。。数据库本身是有缓存机制的,比如评论列表,可能会恰恰相反,如果平时评论用户比较多,每次都要生成文件到磁盘上。。。效率反而会低。。。只有对于那些复杂查询,比如rand或者大数据量的查询,这种才有效果,而且挂的接口不能设置在更新频繁的接口之上。这方法最早在我的NBlue上用过,后续我的主题和插件都没用过这个方法了。
这个很有用,收藏了
博主太牛了,终于帮助我一哥们解决困扰了大半年的问题。谢谢博主。
嗯,真的好快也