47 Star 144 Fork 31

舒建辉 / SpringJPARedis

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README

SpringBoot 开源企业级JPA REDIS无缝整合精细化缓存

前言

本项目发展自2019年,内部版本已在线上大型项目生产环境中使用,经过严格测试,BUG极少,不超过1小时加完缓存扩展,现有的几种缓存方式都有demo,大家可以持续关注,有时间会不断更新,也希望大家积极参与共同开发。 大家有好的建议可以联系本人,一定采纳学习。

第一种方案:只做redis缓存,不保存Mysql数据库, 需加@EnableRedisRepositories注解

优点:配置极省,非常方便,功能强大,支持缓存加索引等

弊端:只能走Redis,不走Mysql,不适合我们通用的开发场景,只适用于以Redis做唯一数据保存的数据库场景
第二种方案:加注解方式  需加@EnableCaching注解

优点:配置较省,较为方便

弊端:虽然走Redis,也走Mysql,但开发中容易出错,缓存删除范围过大,缓存条数过多;加缓存工作量偏大;
第三种方案(推荐):

优点:走Redis,也走Mysql,配置超级省,最为方便,功能可以非常强大,定制化实现,灵活运用,精细化缓存,缓存条数最少,缓存删除范围最小,全动态数据变化的缓存变更,开发中第一层缓存和第二层缓存都支持,并支持事务。

弊端:目前大部分场景都已支持,当然事在人为,可以做到很全面,还可考量并发性能、排序方式、加索引的支持等等场景

QQ交流

  • 作者: 972153513

版本说明

  • 目前发行版本v2.0.RELEASE震撼来袭,父子系统依赖模式请移步项目【 https://gitee.com/shujianhui/new-jpa-redis-parent
  • 修复v1.0.RELEASE所有BUG
  • 重构优化,管道技术执行批处理,火箭提速性能
  • 大型老项目加缓存顶多1小时全部搞完,完美收官
  • 支持Netty异步极速模式(高级Java Redis客户端,用于线程安全同步,异步和反应式使用。支持群集,Sentinel,流水线和编解码器。 https://lettuce.io)
  • 支持抛异常重试5次调取模式

运行必备环境:

  • JDK 8 181 +
  • Maven 3.3.9 +
  • Jedis 2.90
  • MySql 5.7 + 或 MariaDB 10.2 +
  • SpringBoot 1.5.7.RELEASE + (可自己升级版本,下一个版本升级到SpringBoot 2.x)

实现功能:

通用功能

  • Spring事务控制JPA和jedis事务原子性等
  • 支持缓存加载与查询排序
  • 支持Redis单机模式配置
  • 支持Redis哨兵模式配置
  • 支持Redis集群模式配置
  • 支持Redis分片模式配置
  • 支持HikariCP连接池

一层缓存实现(StringRedisTemplate)

  • Controller接口层缓存,无须考虑排序问题,缓存条数可能过多,顶层数据变化比较大,尤其分页和数据展现形式具多样性,但好在接口不多(完全实现)
  • 支持ProtoStuffRedisSerializer最快方式(完全实现)
  • 缓存时间默认4天,不能动态进行数据变化的缓存变更(完全实现)

二层缓存实现(RedisTemplate<String, ?>)

  • JPA 通用增删改查无缝缓存整合(BaseJpaRedisRepositoryImpl)(完全实现)
  • JPA 复杂SQL支持无缝缓存整合(BaseQueryDslJpaRepository)(完全实现)
  • JPA FindBy模式支持无缝缓存整合(SecurecyPostProcessor)(完全实现)
  • JPA @Query注解模式支持无缝缓存整合 (完全实现)
  • 支持ProtoStuffRedisSerializer最快方式(完全实现)
  • 支持KryoRedisSerializer方式(完全实现)
  • 支持FastJsonRedisSerializer方式(完全实现)
  • 支持Jackson2JsonRedisSerializer方式(完全实现)
  • 支持StringRedisSerializer方式(完全实现)
  • 支持JPA和Redis事务整合方式(完全实现)
  • 支持精细化缓存,缓存条数极少,缓存删除范围最小(完全实现)
  • 支持全动态数据变化的缓存变更(完全实现)
  • 支持管道批处理极速模式(完全实现)
  • 支持管道事务超速模式(完全实现)
  • 支持管道事务乐观锁超速模式(完全实现)
  • 支持Netty异步管道批处理极速模式(部分实现)
  • 支持Netty异步管道事务极速模式(部分实现)
  • 支持Netty异步管道事务乐观锁极速模式(部分实现)
  • 支持抛异常重试5次调取模式(完全实现)

空文件

简介

SpringBoot 开源企业级JPA REDIS无缝整合精细化缓存 展开 收起
Java
取消

发行版 (2)

全部

贡献者

全部

近期动态

加载更多
不能加载更多了
Java
1
https://gitee.com/shujianhui/SpringJPARedis.git
git@gitee.com:shujianhui/SpringJPARedis.git
shujianhui
SpringJPARedis
SpringJPARedis
master

搜索帮助