- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
simplespringmemcached统一缓存的使用实例.doc
simple-spring-memcached统一缓存的使用
如何在一个中型的Java应用中使用Memcached缓存数据不是个简单的问题。当某个缓存数据需要在多个系统间共享和失效时,必须要有统一的规划才能保证不出错。经过各种实践,目前系统在使用Memcached缓存数据全部采用Simple-Spring-Memcached框架来完成,并统一规划各系统Spring和Cache key的配置。下面对在使用过程中需要注意的点做一个详细说明:
Cache整体规划
目前我们系统中有两个不同的Memcached服务器:
session memcached服务器:主要存储用户的session
app memcached服务器: 主要用于缓存应用数据
由于应用所有的缓存数据都放在app缓存上,为避免各应用的缓存数据出现冲突,必须规划好它们的命名空间。所幸Simple-Spring-Memcached支持namespace的概念,因此对各应用的namespace前缀规定如下:
应用 namespace前缀 goodscenter goodscenter trade trade uic uic 这个namespace在生成key时,将放在最前面,稍后会有例子详述。同一个应用中存在许多需要缓存的对象,因此约定namespace前缀之后再加上缓存对象的类名。例子如下:
应用 缓存对象 完整的namespace 最终生成的key trade TcRate (id为42) trade:TcRate trade:TcRate:12 goodscenter GoodsDo(id为42) goodscenter:GoodsDo goodscenter:GoodsDo:12 key的生成规则
Simple-Spring-Memcached提供的针对单个对象的注解接口提供了两种key生成方式,详情见此文
AssignCache类注解通过assignKey指定cache的key
SingleCache类注解通过ParameterValueKeyProvider注解指定生成key的方法
对于第一种只要求必须保证key不与其它的冲突,且namesapce符合规则。第二种时,约定缓存的数据对象必须实现有带CacheKeyMethod的cacheKey方法,参考实现如下:
@CacheKeyMethod
public String cacheKey() {
return this.getId();
}
目前@CacheKeyMethod只支持返回String的方法,需要改造成可接受Long,Integer型的。当前必须有单独的方法来作为缓存Key的生成器 真实存放到Memcached的key的生成规则是:namespace:key。如goodscenter的id为42的domain对象GoodsDo,按上述方式生成的key为:goodscenter:GoodsDo:42 spring配置说明
关于Simple-Spring-Memcached具体XML配置如下:
beans xmlns=/schema/beans
xmlns:xsi=/2001/XMLSchema-instance xmlns:aop=/schema/aop
xmlns:context=/schema/context
xsi:schemaLocation=/schema/beans /schema/beans/spring-beans-3.0.xsd
/schema/context /schema/context/spring-context.xsd
/schema/aop /schema/aop/spring-aop-3.0.xsd
import resource=classpath:simplesm-context.xml/
aop:aspectj -autoproxy/
context:annotation -config/
bean name=appCache class=com.google.code.ssm.CacheFactory
property name=cacheClientFactory
bean class=viders.xmemcached.MemcacheClientFactoryImpl/
/property
property name=addressProvider
bean class=com.go
文档评论(0)