用SpringAOP结合MemCached作缓存的设想

方案一:
  • 给DAO的方法上加SpringAOP的Around通知,决定数据从数据库得到仍是从缓存得到。
  • 自定义一个@MemEntity,对此Dao全部按主键和惟一键查询进行缓存。
  • 规则:查询的方法名getByField 更新updateByField 删除deleteByField
  • 其余的方法查询不做缓存,其余的方法更新和删除操做会刷新全部以该类开头的keys
  • 记录缓存时用“类名_方法名_参数值”做为Key,删除缓存时,删除全部的“类名_*_参数值”的key对应的缓存
方案二:
1,给DAO的方法上加SpringAOP的Around通知,决定数据从数据库得到仍是从缓存得到。
2,自定义两个Annotation,@Cache和@Flush,分别加在DAO的查询和修改的方法上。
3,Around通知函数内用反射获取上述的@cache和@Flush,表明是记录缓存,仍是删除缓存。
4,记录缓存时用“类名+方法名+参数的hashcode”做为Key,删除缓存时,删除全部的同类名开头的key对应的缓存。
5,Memcached不支持遍历key,因此采用数据库表记录key,假设:tbl_memcached(key,exp_date)。
6,定义一个时钟,按期删除tbl_memcached的过时记录(删除数据库记录前,删除缓存)。
7,记录缓存时,同时存入一条记录到tbl_memcached表。
8,删除缓存是依据tbl_memcache表的key来进行,而且要删除tbl_memcached表的相关记录。
 
备注:
a:表tbl_memcache(key,exp_date)存储全部memcache的key

 

1:对单个记录进行缓存(查询条件是主键或惟一键):
 存储规则 key  value 
 主键  class_method_id_value  search result
 惟一键  class_method_unique_value class_method_id_value 

存储规则:保存到memcache和tbl_memcache中
更新规则:只更新上面的主键的search result,并更新key为class_select*的数据
 

2:只对经常使用而且基本不会修改的列表查询进行缓存(常常更新不建议缓存)算法

存储规则:key为class_method_hashcode,保存到memcache和tbl_memcache中
更新规则:从tbl_memcahce表中查询全部知足“class_”前缀keys,在memcache和tbl_memcache中删除
 
3:对 查询条件不是主键或惟一键 的数据不进行缓存

4:更新条件不是主键和惟一键的操做(避免这样的操做)数据库

更新规则:从tbl_memcahce表中查询全部知足“class_”前缀keys,在memcache和tbl_memcache中删除
 
5:能够对某一个查询结果进行缓存,key为自定义,任何其余的更新都不会影响它,只有你明确删除此缓存
 
关于tbl_memcahce:

定义一个时钟,按期删除tbl_memcached的过时记录(删除数据库记录前,删除缓存)缓存

默认缓存时间为1个小时,对表的扫描根据时间段进行分配
防止tbl_memcache过于庞大,能够进行分表,规则以下:
1:几个表放入一个tbl_memcache_n
2:根据算法能够任意累加
相关文章
相关标签/搜索