Hibernate是Java编程语言的开放源代码,对象/关系映射框架。Hibernate的目标是帮助开发人员摆脱许多繁琐的手动数据处理任务。Hibernate可以在Java类和数据库表之间以及Java和SQL中的数据类型之间建立映射。html
任何处理大量数据的非平凡应用程序都必须依靠缓存和其余技术来提升效率。缓存是一种经过使用缓冲区存储常常访问的数据来提升应用程序性能的策略。经过减小数据库请求的数量并将数据存储在更靠近CPU的位置,缓存能够显着提升应用程序的速度。java
在本文中,咱们将研究如何使用Redisson(一种用于访问内存中数据结构存储Redis的Java包装器)在Hibernate中执行缓存。git
Hibernate使用多级缓存方案。第一级是强制性的,默认状况下处于启用状态,而第二级是可选的。redis
一级缓存(也称为L1缓存)与Hibernate的Session对象相关联,该对象表示Java应用程序和SQL数据库之间的链接。这意味着仅在会话存在的前提下,一级缓存才可用。每一个第一级缓存只能由与其关联的Session对象访问。数据库
首次从数据库中查询实体时,该实体将存储在与该会话关联的第一级缓存中。在同一会话期间对此实体的任何后续查询都将从缓存而不是数据库中检索实体。编程
二级缓存(也称为L2缓存)默认状况下处于禁用状态,但能够经过修改Hibernate的配置设置来启用。该缓存与Hibernate的SessionFactory对象相关联,主要用于存储应在Session之间持久的数据。在查找第二级缓存以前,应用程序将始终在第一级缓存中搜索给定实体的存在。json
Hibernate还具备第三种类型的缓存:查询缓存,用于存储特定数据库查询的结果。当您须要使用相同的参数屡次运行相同的查询时,这颇有用后端
Hibernate中的二级缓存有几种不一样的实现,包括Ehcache和OSCache。在本文的其他部分中,咱们将探讨Hibernate中用于二级缓存的另外一个选项:Redisson,它容许将Redis用做Hibernate缓存缓存
源码案例- RedissonCacheRegionFactory网络
Redisson是Java中的Redis客户端,其中包含许多Java对象和服务的实现,包括Hibernate缓存。Redisson支持全部四种Hibernate缓存策略:
Redisson提供了各类Hibernate CacheFactories,包括那些支持本地缓存的。若是您打算将Hibernate缓存主要用于读取操做,或者您不想进行太多的网络往返,则本地缓存是一个明智的解决方案。
该 RedissonRegionFactory 工具实现了基本的Hibernate缓存,而 RedissonLocalCachedRegionFactory (在Redisson PRO版本中可用)实现了具备本地缓存支持的Hibernate缓存。
redisson-hibernate 可使用Maven或Gradle 将 依赖项轻松集成到您的项目中。对于JDK 1.8,Maven设置为:
<dependency> <groupId>org.redisson</groupId> <!-- for Hibernate v4.x --> <artifactId>redisson-hibernate-4</artifactId> <!-- for Hibernate v5.0.x - v5.1.x --> <artifactId>redisson-hibernate-5</artifactId> <!-- for Hibernate v5.2.x --> <artifactId>redisson-hibernate-52</artifactId> <!-- for Hibernate v5.3.x - v5.4.x --> <artifactId>redisson-hibernate-53</artifactId> <version>3.10.2</version> </dependency>
而且Gradle设置是:
// for Hibernate v4.x compile 'org.redisson:redisson-hibernate-4:3.10.2' // for Hibernate v5.0.x - v5.1.x compile 'org.redisson:redisson-hibernate-5:3.10.2' // for Hibernate v5.2.x compile 'org.redisson:redisson-hibernate-52:3.10.2' // for Hibernate v5.3.x - v5.4.x compile 'org.redisson:redisson-hibernate-53:3.10.2'
要CacheFactory 在Redisson中定义 in,请在Hibernate配置中插入适当的属性:
<!-- Redisson Region Cache factory --> <property name="hibernate.cache.region.factory_class" value="org.redisson.hibernate.RedissonRegionFactory" /> <!-- or --> <property name="hibernate.cache.region.factory_class" value="org.redisson.hibernate.RedissonLocalCachedRegionFactory" />
您还须要激活Hibernate的二级缓存并指定Redisson配置文件:
<!-- 2nd level cache activation --> <property name="hibernate.cache.use_second_level_cache" value="true" /> <property name="hibernate.cache.use_query_cache" value="true" /> <!-- Redisson YAML config (located in filesystem or classpath) --> <property name="hibernate.cache.redisson.config" value="/redisson.yaml" /> <!-- Redisson JSON config (located in filesystem or classpath) --> <property name="hibernate.cache.redisson.config" value="/redisson.json" />
Redisson容许您为Hibernate缓存更改许多不一样的重要参数,包括:
每一个本地缓存条目的最大空闲时间
一旦达到高速缓存的最大大小(LFU,LRU,SOFT,WEAK或NONE),就对本地高速缓存逐出策略
跨全部实例将更改同步到本地缓存的策略(INVALIDATE,UPDATE或NONE)
链接失败(CLEAR,LOAD或NONE)后从新加载丢失的更新的从新链接策略
Hibernate 二级缓存 - RedissonCacheRegionFactory
mPaaS(Microservice PaaS) 微服务开发平台 基于SpringBoot2.x、SpringCloud并采用先后端分离的多租户系统架构微服务开发平台
喜欢阅读Spring、SpringBoot、SpringCloud等底层源码的能够关注下mPass 微服务开发平台,期待您的宝贵意见!