- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
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
您可能关注的文档
- QQ个性签名字符画.doc
- QQ个性签名档:冷己肤冻己骨心在沸.doc
- QQ个性签名语录人生经典100条.doc
- QQ个性签名:总是羡慕别人恩爱,才发现自己的心是空的.doc
- QQ个性签名:爱你才会吃醋,不爱你连管都不会管.doc
- QQ个性签名:我们就像两只可爱的猪走在爱情大道上,淋浴着爱情的阳光.doc
- QQ个性签名:真可惜没有理由让你陪我.doc
- QQ个性签名:认真活好每一天因为在生命中我们没有第二个今天.doc
- QQ个性网名繁体字:半梦半醒半迷离.doc
- QQ伤感个性签名.doc
- 《成功》读后感 _原创精品文档.pdf
- 【可行性报告】2023年高导热石墨散热材料相关项目可行性研究报告.pdf
- 【可行性报告】2023年避孕药项目可行性研究分析报告 .pdf
- TD-LTE考卷(含答案) _原创精品文档.pdf
- 青年志&Vogue:2024年轻力消费白皮书.pdf
- 钱伯斯全球实践指南:医疗保健行业:医疗设备2024.pdf
- S7-1200PLC应用技术高职课件全套教学课件.pdf
- H5页面设计与制作-精品课件(完整版课件).pdf
- 《原画设计(第二版)》 课件全套 劳动 第1--4章 原画基础---自然现象动作设计.pdf
- 前瞻产业研究院:2024年中国钠离子电池报告-提质降本,探索钠领新未来.pdf
文档评论(0)