CacheManager缓存管理开源工具

本文主要介绍我的开源项目CacheManager的使用说明和特性
https://github.com/Skysper/CacheManager

CacheManager可以协助管理我们项目应用中使用的Redis、Memcache缓存键值对。

目前已经实现了对Redis的支持,支持的数据类型包括String、List、Set、SortedSet、Hash,可以修改、删除键值,设置过期时间等。

1. 创建App信息

创建App

创建app应用,配置连接字符串,支持Redis集群

2. 添加App中使用到的键值

应用使用缓存项

键值规则

缓存Key值名称创建可以包含两种方式:

  • 单项Key值 - 直接对应缓存服务器中特定的Key,如: sys:cache:maxTTL
  • 批量Key值 - 多项Key值,一对多的映射,此Key代表一个Key值序列,该序列支持两种模式
    1. 数值类型,自动+1或-1操作,如 sys:cache:news:{1-10000}
    2. 字符类型, 仅支持Char单字符形式,如 sys:cache:cluster{A-Z}

两种模式可以混合使用,如 sys:cache:cluster{A-Z}:news{1-1000},则查询的Key键列表为:

sys:cache:clusterA:news1
system.cache:clusterA:news2
...
system.cache:clusterA:news1000
system.cache:clusterB:news1
...
cache:clusterZ:news1000

注:多项Key值模式,适合针对单表Id自增等有数值或字符规则的批量缓存进行管理

3.查询管理

设定缓存的值和过期时间

管理TTL

查看列表
缓存结果列表

结果列表根据批量键值规则以及分页页码生成当前页的具体Key值,列出的Key值并不一定真实存在于Redis缓存中,列表中前四项的键值类型分别为String、List、Set、Hash

Hash的键值设置

值Value设置规则
  • String
我可以输入任意内容
  • List、Set
value1
value2
value3
  • Sorted Set
key1$$score1
key2$$score2
key3$$score3
  • Hash
key1$$value1
key2$$value2
key3$$value3
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis Plus提供了默认的Redis缓存管理器,但是有时候我们需要根据自己的业务需求来定制一个适合自己的缓存管理器,这里简单介绍一下如何自定义Redis缓存管理器: 1. 实现Cache接口 首先需要实现MyBatis的Cache接口,该接口定义了缓存操作的基本接口方法。可以参考默认的RedisCache实现。 ``` public interface Cache { String getId(); void putObject(Object key, Object value); Object getObject(Object key); Object removeObject(Object key); void clear(); int getSize(); default void putObject(Object key, Object value, long ttl) { throw new UnsupportedOperationException("not support"); } } ``` 2. 实现CacheManager接口 接着需要实现MyBatis的CacheManager接口,该接口负责管理各个缓存实例的生命周期以及提供创建缓存的方法。可以参考默认的RedisCacheManager实现。 ``` public interface CacheManager { Cache getCache(String var1); void addCache(String var1); Set<String> getCacheNames(); default void destroy() { } } ``` 3. 配置缓存管理器 在MyBatis的配置文件中配置自定义的缓存管理器和缓存实现类。可以像下面这样配置: ``` <cache type="com.example.MyCacheManager"> <!-- 缓存过期时间,单位:秒,默认为永不过期 --> <property name="ttl" value="3600"></property> <!-- RedisHost --> <property name="host" value="localhost"></property> <!-- RedisPort --> <property name="port" value="6379"></property> <!-- RedisPassword --> <property name="password" value=""></property> <!-- RedisDatabase --> <property name="database" value="0"></property> <!-- RedisTimeout --> <property name="timeout" value="5000"></property> </cache> ``` 其中type属性值为自定义的CacheManager实现类。 4. 使用缓存 在Mapper接口方法上使用@CacheNamespace注解开启缓存功能并指定缓存管理器,例如: ``` @Mapper @CacheNamespace(implementation = MyCacheManager.class) public interface UserMapper { @Select("select * from user where id = #{id}") @Options(useCache = true, flushCache = Options.FlushCachePolicy.FALSE) User selectById(@Param("id") int id); } ``` 这样就可以在查询User对象时自动使用自定义的Redis缓存管理器进行缓存

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值