Heim  >  Artikel  >  php教程  >  PHP用memcached做实时分页

PHP用memcached做实时分页

WBOY
WBOYOriginal
2016-06-06 19:43:391120Durchsuche

用memcached做分页缓存,可能很多人会觉得麻烦而不用。因为在增加、修改、删除的过程中,你不知道会影响到哪些数据,而如果把所有分页相关的数据缓存都删除并重新生成一遍,实现又很麻烦,甚至不可行,所以干脆就用mysql直接分页,简单方便,但是这样性能却

     用memcached做分页缓存,可能很多人会觉得麻烦而不用。因为在增加、修改、删除的过程中,你不知道会影响到哪些数据,而如果把所有分页相关的数据缓存都删除并重新生成一遍,实现又很麻烦,甚至不可行,所以干脆就用mysql直接分页,简单方便,但是这样性能却也下降了。 本章就讲一个简单的实现用memcached做分页缓存的方法。
首先假使我们有一个文章页需要做分页显示,分页类型有按分类分页,按最新分页,按热点分页,按自定义方式分页,等等。这就出现了一个比较棘手的问题,我们对数据的更新影响到哪些分页我们是不可知的,不知道需要删除哪些相关的缓存。你可能会想,更新数据时删除所有类型分页的缓存不就好了。那我问你,有多少种分页类型,每个类型各有多少页,key的组成方式各是什么,如果分页带有其他get查询参数,你怎么知道get都传递了哪些值,不知道这些,你怎么删除全部分页缓存。
讲到这里,你可能会觉得有点失望吧,不是吗,没想到用memcached做分页缓存原来这么麻烦。那么,有没有简单的解决方案?答案是肯定的,请相信,我写这篇文章的目的,就是来告诉你一个简单的解决方案来的。说了这么多,其实我们需要解决的核心问题就只有一个,我们增加、修改、删除文章数据时,能够让分页的缓存都失效。解决方案也很简单,我们只需要引入版本号就可以了,在所有受影响的memcached的key中都加入版本号,当我们增加、修改、删除文章数据时,版本号+1,这样就等于所有分页相关的缓存都失效了。

<span>//</span><span>备注:假使下面函数都已经已经初始化$memcached了 </span>
<span>class</span><span> Article 
{ 
    </span><span>private</span> <span>$article_version</span> = 'article_version'<span>; 
     
    </span><span>public</span> <span>function</span> getArticle(<span>$type</span>='new',<span>$page</span>='1',<span>$limit</span>=0<span>){      
        </span><span>//</span><span>设置memcached的key,在key的末端加上版本号 </span>
        <span>$cache_id</span> = 'art_type'.<span>$type</span>.'_page'.<span>$page</span>.'_limit'.<span>$limit</span>.'v_'.<span>$this</span>-><span>_getArticleVersion();         
        </span><span>//</span><span>得到分页数据 </span>
        <span>$artdata</span> = <span>$memcached</span>->get(<span>$cache_id</span><span>); 
        </span><span>if</span>( <span>FALSE</span> === <span>$artdata</span><span>) { 
            </span><span>//</span><span>重新从数据库得到数据并设置新的memcached缓存     </span>
<span>        } 
        </span><span>return</span> <span>$artdata</span><span>; 
    } 
     
    </span><span>public</span> <span>function</span> updateArticle(<span>$conditions</span>,<span>$data</span><span>){ 
        </span><span>//</span><span>更新数据库数据操作 
         
        //更新Article的版本,这样所有Article表相关的缓存就都失效了,下次调用getArticle函数的时候将生成新的缓存数据 </span>
        <span>$this</span>-><span>_setArticleVersion(); 
    } 
     
    </span><span>private</span> <span>function</span><span> _getArticleVersion(){ 
        </span><span>$article_version_num</span> = <span>$memcached</span>->get(<span>$this</span>-><span>article_version); 
        </span><span>if</span>( <span>FALSE</span> === <span>$article_version_num</span><span>){ 
            </span><span>$article_version_num</span> = 1<span>; 
            </span><span>$memcached</span>->set(<span>$this</span>->article_version, <span>$article_version_num</span>, 86400<span>); 
        } 
        </span><span>return</span> <span>$article_version_num</span><span>; 
    } 
     
    </span><span>private</span> <span>function</span><span> _setArticleVersion(){ 
        </span><span>$article_version_num</span> = <span>$memcached</span>->get(<span>$this</span>-><span>article_version); 
        </span><span>$article_version_num</span>++<span>; 
        </span><span>$memcached</span>->set(<span>$this</span>->article_version, <span>$article_version_num</span>, 86400<span>); 
    } 
 
} </span>

     是不是很简单?也就是比平常的memcached缓存多了两个函数_ getArticleVersion()和_ setArticleVersion(),这样当我们有增加、修改、删除文章的时候,就调用_ setArticleVersion()函数,使版本号+1,也就是之前版本的数据都失效了,由于在获得文章分页缓存数据时key都有加入_ getArticleVersion(),所以得不到新版本号的缓存数据,就从数据库查到,然后生成新版本的缓存,旧的缓存在时间过期之后会自动释放内存空间。

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