`
nannan408
  • 浏览: 1783520 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Ehcached等与Oscached的比较

 
阅读更多
1.前言.
  j2ee可以有很多Cache策略,Ehcached,memcached,oscached,redis等,总体来说,其他的都优于,oscached.
2.具体内容。
   因为oscached不支持分布式,不支持异步缓存,不提供批量缓存条目的接口,并且有NeedsRefreshException(当缓存条目过期或者不存在的时候,抛出异常,会将此时的key死锁。这个时候需要调用putlnCache或者cancellUpdate来解除死锁。)
  出现这个异常时候,解决的代码类似如下:
   String myKey="myKey";
   String myValue;
   int myRefreshPeriod=1000;
   try{
       //Get from the cache
       myValue=(String)admin.getFromCache(myKey,myRefreshPeriod);
    }catch(NeedsRefreshException nre){
       try{
         //Get the value(probably by calling an EJB)
         myValue="This is the content retrieved";
         //Store in the cache
         admin.putlnCache(myKey,myValue);
         updated=true;
    }finally{
            if(!updated){
             //it is essential that cancelUpdate is  called if the
             //cached content could not be rebuit
             admin.cancelUpdate(myKey);

     }
    }
3.总结.
  选型尽量避免Oscached,redis等可以考虑,memcached需要解决其list遍历有时候找不到对象的bug问题,但oscached在业务定制还是比较出色,实现比较简单,不需要分布式等可以考虑 。
1
7
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics