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

PHP用memcached做实时分页

WBOY
WBOYasal
2016-06-06 19:43:391120semak imbas

用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(),所以得不到新版本号的缓存数据,就从数据库查到,然后生成新版本的缓存,旧的缓存在时间过期之后会自动释放内存空间。

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn