在开发项目时,我们有时会将一些比较固定的数据加载到缓存中,从而提高系统的响应速度,而ecache是一个非常好用的缓存框架。
echache具体的使用方法就网上找了,说一下自己在使用过程中的发现的一个问题。
public interface RestDayService {
Double getWorkInterval(Timestamp startTime,Timestamp endTime);
}
上面这个是service接口
@Service
public class RestDayServiceImpl implements RestDayService{
@Resource
private RestDayMapper restDayMapper;
@Override
public Double getWorkInterval(Timestamp startTime, Timestamp endTime) {
List<RestDayVo> list = this.getRestList(Utils.Time2Zero(startTime),Utils.Time2Zero(endTime));
...
}
@Cacheable(value = "restDayCache")
private List<RestDayVo> getRestList(Timestamp startTime, Timestamp endTime) {
System.out.println("enter:"+startTime.getTime());
...
}
}
我在接口实现中对其中的一个内部方法加了缓存,缓存下数据库的查询数据,而外部调用的是别个一个对外提供的public方法,但在调试的过程中,就是缓存不到数据,ecache失效了。网上找了半天,有的说是private要换成public,但换了也不起作用。
最后实在没办法了,只有自己写代码调试了。
终于在调试的过程中,发现ecahce针对service这种,不能缓存内部方法,只能修改成下面这种了。
public interface RestDayService {
Double getWorkInterval(Timestamp startTime,Timestamp endTime);
List<RestDayVo> getRestList(Timestamp startTime,Timestamp endTime);
}
@Service
public class RestDayServiceImpl implements RestDayService{
@Resource
private RestDayMapper restDayMapper;
@Resource
//这个的原因是要使用echache缓存数据
private RestDayService restDayService;
@Override
public Double getWorkInterval(Timestamp startTime, Timestamp endTime) {
List<RestDayVo> list = restDayService.getRestList(Utils.Time2Zero(startTime),Utils.Time2Zero(endTime));
...
}
@Override
@Cacheable(value = "restDayCache")
public List<RestDayVo> getRestList(Timestamp startTime, Timestamp endTime) {
System.out.println("enter:"+startTime.getTime());
...
}
}
这样调用,缓存就生效了。
这只是一种解决办法,其实可以把调用的方法放到其他的service中,这样就不会出现这个问题了。
至于其中的原因,只有去查看ecache源码了。
另外有一个问题,就是@cachealbe是否可以直接写到mapper接口上,而不用每次写到service的实现上。