Skip to content

msimw/mcache

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

关于统一缓存工具的使用与扩展说明

1.作用:

系统统一缓存,让开发者不用管缓存的具体实现,更专注于业务逻辑。

2.实现功能:

粗粒度的缓存+相对细粒度的缓存。

Maven

<dependency> <groupId>com.github.msimw</groupId> <artifactId>mcache</artifactId> <version>1.0</version> </dependency> 

3.如何使用:

1.注解的介绍: 1.Cached 1.用在类上,用于标记需要缓存的类。 2.属性value用于标示缓存分组,默认值cache 2.Cacheable 1.用在需要缓存的方法上。 2.属性cache 标示使用哪一种缓存方式。目前支持redis,memcache。 3.属性value 用于标示缓存分组,默认值bst。 4.属性String[] keys用于标示用那几个字段作为缓存key。可以是参数或参数的属性, 当有多个重复的属性名时:可以使用[参数名.属性名]的形式(user.name)。 5.属性survivalTime缓存存活时间,默认30分钟,单位是秒。-1标示永不过期。 3.CacheEvict 或者 CacheEvicts(表示多个CacheEvict 清空多个缓存) 1.用在缓存有更新的方法上。 2.属性介绍参见 Cacheable 4.对于部分统一缓存满足不了的需求可使用CacheSupport接口来手动控制。 5.引入applicationContext-cache.xml文件到需要缓存的工程中。 

4.如何扩展

 1.实现CacheHandler接口或继承AbstractCacheHandler类 2.将新的缓存处理器注入到CacheInterceptor 拦截器中 3.就可以在Cacheable注解上选择相应缓存处理器了。 

5.Demo

 1.代码示例 @Cached public class DemoServiceImpl implements IDemoService { /** * 缓存 */ @Cacheable(keys = "id") public String query(String id, String name) { return "helloworld"; } /** * 更新 */ @CacheEvict(keys = "id") public void update(String id, String name) { } /** * 查询 */ @Cacheable(keys = "id") @Override public String query1(String id) { return null; } /** * 更新 */ @CacheEvict(keys = "id")//or @CacheEvict(keys = "demo.id") @Override public void update1(Demo demo) { } } 2.配置文件 <import resource="classpath:cache/applicationContext-cache.xml"></import> <bean id="demoService" class="com.msimw.demo.service.DemoServiceImpl"></bean> 2017-07-18 

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages