用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:根据算法可以任意累加

posted on 2018-11-21 19:58  xiaowater  阅读(104)  评论(0)    收藏  举报

导航