欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Ehcached等与Oscached的比较

程序员文章站 2022-03-01 22:17:45
...
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在业务定制还是比较出色,实现比较简单,不需要分布式等可以考虑 。