ehcache 缓存的使用

2014-11-24 11:14:50 · 作者: · 浏览: 0
在“Struts2开发,自定义标签的使用——编码自动转化为中文含义”发现,编码转换有点慢,页面像帷幕一样缓缓显示,问题主要是由于后台处理服务类拿到编码ID去 数据库中查询到相应的编码中文含义,每一个ID都要如此的操作,当然数据展现比较慢,所以可能需要进一步的优化,于是第一时间就想到缓存机制。通过缓存来优化数据的获取效率。
采用的是ehcache 缓存,需要引入ehcache.jar 支持包。主要就是优化数据库操作层的代码。
1、定义缓存工具类 EhcacheUtil.java:
package lsxy.report.tool;
import net.sf.ehcache.CacheException;
import net.sf.ehcache.CacheManager;
public class EhcacheUtil {
private EhcacheUtil() {
}
private static CacheManager cacheManager = null;
static {
try {
cacheManager = CacheManager.create();
} catch (CacheException e) {
e.printStackTrace();
}
}
public static CacheManager getCacheManager() {
return cacheManager;
}
}
2、数据库操作层类代码引入ehcache 后的优化:
public class ReportCodeDao {
private BasicDB db = new BasicDB();
/**
* 根据codeId获取对应的名称
*
* @param cid
* @return
* @throws CacheException
* @throws IllegalStateException
*/
public String getCodeDesc(String cid) throws Exception {
String codedesc = "";
// 获取CacheManager
CacheManager cacheManager = EhcacheUtil.getCacheManager();
// 用配置文件中配置的colorcache创建cache缓存
Cache cache = cacheManager.getCache("codeCache");
// 查看cache中是否存在cid的缓存
Element element = cache.get(cid);
// 如果不存在,从数据库中查询
if (element == null) {
String sql = "select codedesc from TBL_REPORT_CODEDESC where cid='"
+ cid + "'";
// System.out.println("从数据库中查询!" + sql);
ResultSet rs = db.executeQuery(sql);
try {
if (rs.next())
codedesc = rs.getString("codedesc");
} catch (SQLException e) {
e.printStackTrace();
} finally {
db.closed();
}
cache.put(new Element(cid, codedesc));
} else {// 如果存在,从缓存中加载
// System.out.println("从缓存中加载!");
codedesc = element.getValue().toString();
}
// System.out.println("codedesc:" + codedesc);
return codedesc;
}
3、缓存配置文件ehcache.xml
timeToIdleSeconds="120" timeToLiveSeconds="120" overflowToDisk="true" />
timeToIdleSeconds="300" timeToLiveSeconds="600" overflowToDisk="true" />