您的位置:首页 > 数据库 > Memcache

使用Simple-Spring-Memcached注解做缓存操作

2015-11-24 10:20 615 查看


使用Simple-Spring-Memcached注解做缓存操作

2014-06-10 15:16 4798人阅读 评论(0) 收藏 举报


分类:

memcache(14)


之前自己写过一个通过注解和AOP来实现缓存的代码,当时这段代码写得比较简单,之后重构时发现之前的功能实现有很大的局限。主要问题在于:

key的生成规则
update 与 query 的参数不一样,如何让其生成一样的key
列表缓存如何定义key及失效

最近同事推荐了一个开源项目:Simple-Spring-Memcached,它也是一个通过Annatation与AOP来完成缓存数据操作的开源项目。仔细看了一下代码,基本上把我之前碰到的问题都解决了,而且MultiCache这一块的实现超出我的预期。该项目主要优点如下:

与Spring完善集成
支持两种Memcached Java Client (spymemcached,Xmemcached)
基于Annotation方式实现缓存操作,对代码侵入性小
annotation丰富,可以满足绝大部分需求

下面介绍一下其中各annotation的使用。ssm项目中的Annotation主要分成以下几类

SingleCache类 操作单个POJO的Cache数据,由ParameterValueKeyProvider和CacheKeyMethod来标识组装key
MultiCache类 操作List型的Cache数据,由ParameterValueKeyProvider和CacheKeyMethod来标识组装key
AssignCache类 指定key操作Cache数据,由annotation中的 assignedKey 指定key

各Annotation的详细说明

ReadThroughSingleCache

作用:读取Cache中数据,如果不存在,则将读取的数据存入Cache

key生成规则:ParameterValueKeyProvider指定的参数,如果该参数对象中包含CacheKeyMethod注解的方法,则调用其方法,否则调用toString方法

代码示例:

[java] view
plaincopyprint?

@ReadThroughSingleCache(namespace = "Alpha", expiration = 30)

public String getDateString(@ParameterValueKeyProvider final String key) {

final Date now = new Date();

try {

Thread.sleep(1500);

} catch (InterruptedException ex) {

}

return now.toString() + ":" + now.getTime();

}

InvalidateSingleCache

作用:失效Cache中的数据

key生成规则:

使用 ParameterValueKeyProvider注解时,与ReadThroughSingleCache一致
使用 ReturnValueKeyProvider 注解时,key为返回的对象的CacheKeyMethod或toString方法生成

[java] view
plaincopyprint?

@InvalidateSingleCache(namespace = "Charlie")

public void updateRandomString(@ParameterValueKeyProvider final Long key) {

// Nothing really to do here.

}

@InvalidateSingleCache(namespace = "Charlie")

@ReturnValueKeyProvider

public Long updateRandomStringAgain(final Long key) {

return key;

}

UpdateSingleCache

作用:更新Cache中的数据

key生成规则:ParameterValueKeyProvider指定

ParameterDataUpdateContent:方法参数中的数据,作为更新缓存的数据

ReturnDataUpdateContent:方法调用后生成的数据,作为更新缓存的数据

注:上述两个注解,必须与Update*系列的注解一起使用

[java] view
plaincopyprint?

@UpdateSingleCache(namespace = "Alpha", expiration = 30)

public void overrideDateString(final int trash, @ParameterValueKeyProvider final String key,

@ParameterDataUpdateContent final String overrideData) {

}

@UpdateSingleCache(namespace = "Bravo", expiration = 300)

@ReturnDataUpdateContent

public String updateTimestampValue(@ParameterValueKeyProvider final Long key) {

try {

Thread.sleep(100);

} catch (InterruptedException ex) {

}

final Long now = new Date().getTime();

final String result = now.toString() + "-U-" + key.toString();

return result;

}

ReadThroughAssignCache

作用:读取Cache中数据,如果不存在,则将读取的数据存入Cache

key生成规则: ReadThroughAssignCache 注解中的 assignedKey 字段指定

[java] view plaincopyprint?@ReadThroughAssignCache(assignedKey = "SomePhatKey", namespace = "Echo", expiration = 3000)
public List<String> getAssignStrings() {
try {
Thread.sleep(500);
} catch (InterruptedException ex) {
}
final List<String> results = new ArrayList<String>();
final long extra = System.currentTimeMillis() % 20;
final String base = System.currentTimeMillis() + "";
for (int ix = 0; ix < 20 + extra; ix++) {
results.add(ix + "-" + base);
}
return results;
}

InvalidateAssignCache
作用:失效缓存中指定key的数据
key生成规则:assignedKey 字段指定

@InvalidateAssignCache(assignedKey = "SomePhatKey", namespace = "Echo")
public void invalidateAssignStrings() {
}
UpdateAssignCache
作用:更新指定缓存
key生成规则:assignedKey 字段指定

@UpdateAssignCache(assignedKey = "SomePhatKey", namespace = "Echo", expiration = 3000)
public void updateAssignStrings(int bubpkus, @ParameterDataUpdateContent final List<String> newData) {
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: