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在业务定制还是比较出色,实现比较简单,不需要分布式等可以考虑 。
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在业务定制还是比较出色,实现比较简单,不需要分布式等可以考虑 。
推荐阅读