项目完结,整理一些技术方面的相关收获。
已经记不得EhCacheController这个实现类最早来自于那里了,总之稍加修改后非常有效果,大家就这么用了,感谢最初开源的那位兄弟。这里,主要是做个记录,为以后类似扩展(譬如Memcached)做个准备。

iBatis提供CacheController接口,用于实现第三方缓存架构的扩展。

这里以iBatis 2.3.0,EhCache 1.2.3版本为基础,构建iBatis+EhCache实现。

EhCacheController类:

package com.ibatis.sqlmap.engine.cache.ehcache;

import java.net.URL;
import java.util.Properties; import net.sf.ehcache.Cache;
import net.sf.ehcache.CacheManager;
import net.sf.ehcache.Element; import com.ibatis.sqlmap.engine.cache.CacheController;
import com.ibatis.sqlmap.engine.cache.CacheModel; /**
* EhCache Implementation of the
* {@link com.ibatis.sqlmap.engine.cache.CacheController} interface to be able
* to use EhCache as a cache implementation in iBatis. You can configure your
* cache model as follows, by example, in your sqlMapping files:
*
* <pre>
* <code>
* <cacheModel id="myCache" readOnly="true" serialize="false"
* type="com.ibatis.sqlmap.engine.cache.EhCacheController" >
* <property name="configLocation"
* value="/path-to-ehcache.xml"/>
* </cacheModel> </code>
* </pre>
*
* Alternatively, you can use a type alias in your type attribute and defining
* the class with a <code><typeAlias></code> declaration:
*
* <pre>
* <code>
* <sqlMapConfig>
* <typeAlias alias="EHCACHE"
* type="com.ibatis.sqlmap.engine.cache.ehcache.EhCacheController" />
* </sqlMapConfig>
* </code>
* </pre>
*
*/
public class EhCacheController implements CacheController { /**
* The EhCache CacheManager.
*/
private CacheManager cacheManager; public static final String CONFIG_LOCATION = "configLocation"; /**
* Default Configure Location
*/
public static final String DEFAULT_CONFIG_LOCATION = "/ehcache.xml"; /**
* Flush a cache model.
*
* @param cacheModel
* - the model to flush.
*/
public void flush(CacheModel cacheModel) {
getCache(cacheModel).removeAll();
} /**
* Get an object from a cache model.
*
* @param cacheModel
* - the model.
* @param key
* - the key to the object.
* @return the object if in the cache, or null(?).
*/
public Object getObject(CacheModel cacheModel, Object key) {
Object result = null;
Element element = getCache(cacheModel).get(key);
if (element != null) {
result = element.getObjectValue();
}
return result; } /**
* Put an object into a cache model.
*
* @param cacheModel
* - the model to add the object to.
* @param key
* - the key to the object.
* @param object
* - the object to add.
*/
public void putObject(CacheModel cacheModel, Object key, Object object) {
getCache(cacheModel).put(new Element(key, object));
} /**
* Remove an object from a cache model.
*
* @param cacheModel
* - the model to remove the object from.
* @param key
* - the key to the object.
* @return the removed object(?).
*/
public Object removeObject(CacheModel cacheModel, Object key) {
Object result = this.getObject(cacheModel, key);
getCache(cacheModel).remove(key);
return result;
} /**
* Gets an EH Cache based on an iBatis cache Model.
*
* @param cacheModel
* - the cache model.
* @return the EH Cache.
*/
private Cache getCache(CacheModel cacheModel) {
String cacheName = cacheModel.getId();
Cache cache = cacheManager.getCache(cacheName);
return cache;
} /**
* Shut down the EH Cache CacheManager.
*/
public void finalize() {
if (cacheManager != null) {
cacheManager.shutdown();
}
} /**
* Configure a cache controller. Initialize the EH Cache Manager as a
* singleton.
*
* @param props
* - the properties object continaing configuration information.
*/
@Override
public void configure(Properties props) {
String configLocation = props.getProperty(CONFIG_LOCATION);
// if can not found ehcache.xml from configLocaion,
// use default configure file.
if (configLocation == null) {
configLocation = DEFAULT_CONFIG_LOCATION;
}
URL url = getClass().getResource(configLocation);
cacheManager = CacheManager.create(url);
}
}

这里默认在根目录下获取ehcache.xml文件,可以通过cacheModel配置进行修改。

在SqlMapConfig.xml文件中配置一个别名,作为全局变量,供其余SqlMap使用

<typeAlias
alias="EHCACHE"
type="com.ibatis.sqlmap.engine.cache.ehcache.EhCacheController" />

顺便提一句,要使用缓存注意SqlMapConfig.xml文件中settings节点配置cacheModelsEnabledtrue

	<settings
cacheModelsEnabled="true"
useStatementNamespaces="true"
...
/>

如果要变更ehcache.xml文件路径为/config/ehcache.xml,可以在上述节点中下入如下代码:

<property name="configLocation" value="/config/ehcache.xml" />

然后,就可以通过ehcache.xml控制ehcache缓存了!

举例说明iBatis SqlMap & ehcahce.xml,以免有些兄弟混淆!

以Account类为示例,在SqlMap中的配置为:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE sqlMap
PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN"
"http://ibatis.apache.org/dtd/sql-map-2.dtd">
<sqlMap
namespace="Account">
<cacheModel
id="cache"
type="EHCACHE">
<flushInterval
hours="1" />
<!-- flush操作,需要指明 Namespace -->
<flushOnExecute
statement="Account.create" />
</cacheModel>
<typeAlias
alias="account"
type="org.zlex.acl.Account" />
<resultMap
id="accountMap"
class="account">
<result
property="accountId"
column="accountId" />
<result
property="accountName"
column="accountName" />
<result
property="mail"
column="mail" />
<result
property="realName"
column="realName" />
<result
property="status"
column="status" />
<result
property="lastLoginTime"
column="lastLoginTime" />
</resultMap>
<select
id="readByAccountName"
parameterClass="string"
resultMap="accountMap"
cacheModel="cache">
<![CDATA[
SELECT
accountId,
accountName,
mail,
realName,
status,
lastLoginTime
FROM
acl_account
WHERE
accountName = #accountName#
]]>
</select>
<insert
id="create"
parameterClass="account">
<![CDATA[
INSERT INTO
acl_account(
accountName,
mail,
realName,
status,
lastLoginTime
)
VALUES (
#accountName#,
#mail#,
#realName#,
#status#,
#lastLoginTime#
)
]]>
<selectKey
resultClass="long"
keyProperty="accountId">
<![CDATA[select LAST_INSERT_ID() as id ]]>
</selectKey>
</insert>
</sqlMap>

注意:

引用
<select
id="readByAccountName"
parameterClass="string"
resultMap="accountMap"
cacheModel="cache">

这里的cacheModel="cache",对应的在ehcache.xml中就应该是:

	<cache
name="Account.cache"
maxElementsInMemory="10000"
eternal="false"
maxElementsOnDisk="1000"
overflowToDisk="true"
timeToIdleSeconds="300"
/>

因为,我使用了useStatementNamespaces="true"

缓存初解(四)---Ibatis的缓存配置+Ehcache的更多相关文章

  1. 缓存初解(三)---Spring3.0基于注解的缓存配置+Ehcache和OScache

    本文将构建一个普通工程来说明spring注解缓存的使用方式,关于如何在web应用中使用注解缓存,请参见: Spring基于注解的缓存配置--web应用实例 一.简介 在spring的modules包中 ...

  2. Spring自定义缓存管理及配置Ehcache缓存

    spring自带缓存.自建缓存管理器等都可解决项目部分性能问题.结合Ehcache后性能更优,使用也比较简单. 在进行Ehcache学习之前,最好对Spring自带的缓存管理有一个总体的认识. 这篇文 ...

  3. 缓存初解(五)---SpringMVC基于注解的缓存配置--web应用实例

    之前为大家介绍了如何使用spring注解来进行缓存配置 (EHCache 和 OSCache)的简单的例子,详见 Spring基于注解的缓存配置--EHCache AND OSCache 现在介绍一下 ...

  4. 在 JPA、Hibernate 和 Spring 中配置 Ehcache 缓存

    jpa, hibernate 和 spring 时配置 ehcache 二级缓存的步骤. 缓存配置 首先在 persistence.xml 配置文件中添加下面内容: <property name ...

  5. Spring Boot中的缓存支持(一)注解配置与EhCache使用

    Spring Boot中的缓存支持(一)注解配置与EhCache使用 随着时间的积累,应用的使用用户不断增加,数据规模也越来越大,往往数据库查询操作会成为影响用户使用体验的瓶颈,此时使用缓存往往是解决 ...

  6. MyBatis学习总结(四)——MyBatis缓存与代码生成

    一.MyBatis缓存 缓存可以提高系统性能,可以加快访问速度,减轻服务器压力,带来更好的用户体验.缓存用空间换时间,好的缓存是缓存命中率高的且数据量小的.缓存是一种非常重要的技术. 1.0.再次封装 ...

  7. spring整合ehcache注解实现查询缓存,并实现实时缓存更新或删除

    转载: http://www.importnew.com/23358.html 写在前面:上一篇博客写了spring cache和ehcache的基本介绍,个人建议先把这些最基本的知识了解了才能对今天 ...

  8. spring整合ehcache 注解实现查询缓存,并实现实时缓存更新或删除

    写在前面:上一篇博客写了spring cache和ehcache的基本介绍,个人建议先把这些最基本的知识了解了才能对今天主题有所感触.不多说了,开干! 注:引入jar <!-- 引入ehcach ...

  9. 2.spring整合ehcache 注解实现查询缓存,并实现实时缓存更新或删除

    转自:http://www.importnew.com/23358.html 写在前面:上一篇博客写了spring cache和ehcache的基本介绍,个人建议先把这些最基本的知识了解了才能对今天主 ...

随机推荐

  1. 层叠水平(stacking level)

    运用上图的逻辑,上面的题目就迎刃而解,inline-blcok 的 stacking level 比之 float 要高,所以无论 DOM 的先后顺序都堆叠在上面. 不过上面图示的说法有一些不准确,按 ...

  2. oracle中的存储过程例子

    用了两年Oracle还没写过存储过程,真是十分惭愧,从今天开始学习Oracle存储过程,完全零起点,争取每日一篇学习笔记,可能开始认识的不全面甚至有错误,但坚持下来一定会有收获. . 建立一个存储过程 ...

  3. js 数组去重复键

    Array.prototype.deleteEle = function() { var newArr = this; for (var i = newArr.length - 1; i >= ...

  4. selenium+python find_element_by_css_selector方法使用

    1.通过类class获取 比如如下代码 <h1 class="important"> This heading is very important. </h1&g ...

  5. SQL Server 2014 Always on ON Microsoft Azure New Portal(1)

    以前假如需要在Azure IaaS 创建的SQL Server AlwaysOn 需要参考以下的步骤 From the MVPs: SQL Server High Availability in Wi ...

  6. Object.keys()

    Object.keys(obj),返回一个数组,数组里是该obj可被枚举的所有属性名.请看示例: 示例一: function Pasta(grain, width, shape) { this.gra ...

  7. mysql 连接语句

    在 SELECT 语句中,如果 FROM 子句引用了多个表源或视图,可以使用 JOIN 指示指定的联接操作应在指定的表源或视图之间执行. 一.交叉联接:CROSS JOIN 交叉联接将执行一个叉积(迪 ...

  8. ASP.NET MVC NonActionAttribute使用说明

    默认情况下,MVC 框架将 controller 类的所有公共方法都视为操作方法. 如果您的 controller 类包含公共方法,并且您不希望它成为操作方法,则必须用 NonActionAttrib ...

  9. How to Implement Bluetooth Low Energy (BLE) in Ice Cream Sandwich

    ShareThis - By Vikas Verma Bluetooth low energy (BLE) is a feature of Bluetooth 4.0 wireless radio t ...

  10. 保持程序在后台长时间运行-b

    iOS为了让设备尽量省电,减少不必要的开销,保持系统流畅,因而对后台机制采用墓碑式的“假后台”.除了系统官方极少数程序可以真后台,一般开发者开发出来的应用程序后台受到以下限制:1.用户按Home之后, ...