Hibernate是Java编程语言的开放源代码,对象/关系映射框架。Hibernate的目标是帮助开发人员摆脱许多繁琐的手动数据处理任务。Hibernate能够在Java类和数据库表之间以及Java和SQL中的数据类型之间创建映射。

任何处理大量数据的非平凡应用程序都必须依靠缓存和其他技术来提高效率。缓存是一种通过使用缓冲区存储经常访问的数据来提高应用程序性能的策略。通过减少数据库请求的数量并将数据存储在更靠近CPU的位置,缓存可以显着提高应用程序的速度。

在本文中,我们将研究如何使用Redisson(一种用于访问内存中数据结构存储Redis的Java包装器)在Hibernate中执行缓存。

Hibernate 第一级 \ 二级缓存

Hibernate使用多级缓存方案。第一级是强制性的,默认情况下处于启用状态,而第二级是可选的。

一级缓存

一级缓存(也称为L1缓存)与Hibernate的Session对象相关联,该对象表示Java应用程序和SQL数据库之间的连接。这意味着仅在会话存在的前提下,一级缓存才可用。每个第一级缓存只能由与其关联的Session对象访问。

首次从数据库中查询实体时,该实体将存储在与该会话关联的第一级缓存中。在同一会话期间对此实体的任何后续查询都将从缓存而不是数据库中检索实体。

二级缓存

二级缓存(也称为L2缓存)默认情况下处于禁用状态,但可以通过修改Hibernate的配置设置来启用。该缓存与Hibernate的SessionFactory对象相关联,主要用于存储应在Session之间持久的数据。在查找第二级缓存之前,应用程序将始终在第一级缓存中搜索给定实体的存在。

Hibernate还具有第三种类型的缓存:查询缓存,用于存储特定数据库查询的结果。当您需要使用相同的参数多次运行相同的查询时,这很有用

Hibernate中的二级缓存有几种不同的实现,包括Ehcache和OSCache。在本文的其余部分中,我们将探讨Hibernate中用于二级缓存的另一个选项:Redisson,它允许将Redis用作Hibernate缓存

如何使用Hibernate和Redis进行缓存

源码案例- RedissonCacheRegionFactory

选择策略

Redisson是Java中的Redis客户端,其中包含许多Java对象和服务的实现,包括Hibernate缓存。Redisson支持所有四种Hibernate缓存策略:

  • READ_ONLY:仅用于在缓存内部不会更改的实体。
  • NONSTRICT_READ_WRITE:在事务修改数据库中的实体之后,更新缓存。无法保证强一致性,但可以保证最终一致性。
  • READ_WRITE:通过使用“软”锁来保证强一致性,这些锁将保持对实体的控制,直到事务完成为止。
  • 事务性:通过使用分布式XA事务确保数据完整性。确保将更新提交或回滚到数据库和缓存。

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缓存更改许多不同的重要参数,包括:

  • Redis中缓存的最大大小
  • Redis中每个缓存条目的生存时间
  • Redis中每个缓存条目的最大空闲时间
  • 本地缓存的最大大小
  • 每个本地缓存条目的生存时间

每个本地缓存条目的最大空闲时间

一旦达到高速缓存的最大大小(LFU,LRU,SOFT,WEAK或NONE),就对本地高速缓存逐出策略

跨所有实例将更改同步到本地缓存的策略(INVALIDATE,UPDATE或NONE)

连接失败(CLEAR,LOAD或NONE)后重新加载丢失的更新的重新连接策略

Hibernate 二级缓存 - RedissonCacheRegionFactory

mPaaS(Microservice PaaS) 微服务开发平台 基于SpringBoot2.x、SpringCloud并采用前后端分离的多租户系统架构微服务开发平台

喜欢阅读Spring、SpringBoot、SpringCloud等底层源码的可以关注下mPass 微服务开发平台,期待您的宝贵意见!

使用Redis在Hibernate中进行缓存的更多相关文章

  1. 【Hibernate】解析hibernate中的缓存

    Hibernate中的缓存一共有三种,一级缓存.二级缓存.查询缓存.缓存除了使用Hibernate自带的缓存,还可以使用redis进行缓存,或是MongoDB进行缓存. 所使用的Demo: User. ...

  2. hibernate中的缓存机制

    一.为什么要用Hibernate缓存? Hibernate是一个持久层框架,经常访问物理数据库. 为了降低应用程序对物理数据源访问的频次,从而提高应用程序的运行性能. 缓存内的数据是对物理数据源中的数 ...

  3. 分布式数据存储 之 Redis(二) —— spring中的缓存抽象

    分布式数据存储 之 Redis(二) -- spring中的缓存抽象 一.spring boot 中的 StringRedisTemplate 1.StringRedisTemplate Demo 第 ...

  4. JavaWeb_(Hibernate框架)Hibernate中一级缓存

    Hibernate中一级缓存 Hibernate 中的缓存分为一级缓存和二级缓存,这两个级别的缓存都位于持久化层,并且存储的都是数据库数据的备份.其中一级缓存是 Hibernate 的内置缓存,在前面 ...

  5. Hibernate中一级缓存和二级缓存使用详解

    一.一级缓存二级缓存的概念解释 (1)一级缓存就是Session级别的缓存,一个Session做了一个查询操作,它会把这个操作的结果放在一级缓存中,如果短时间内这个 session(一定要同一个ses ...

  6. hibernate中的缓存问题与快照机制

    1.  什么是缓存 数据存储到数据库里面,数据库本身是一个文件系统,使用流方式操作文件(效率不高) 改进方式:把数据存到内存中,不需要使用流方式,可以直接读取内存中的数据 缓存:内存中的临时数据,当内 ...

  7. Hibernate中一级缓存和二级缓存

    缓存是介于应用程序和物理数据源之间,其作用是为了降低应用程序对物理数据源访问的频次,从而提高了应用的运行性能.缓存内的数据是对物理数据源中的数据的复制,应用程序在运行时从缓存读写数据,在特定的时刻或事 ...

  8. Hibernate中一级缓存概念以及flush与clear的区别

    Hibernate采用缓存机制提高数据查询效率.缓存分为一级缓存和二级缓存,一级缓存在Session中存在,二级缓存需要手动配置. 在一级缓存中,如果数据保存到数据库中后,而session又没有关闭的 ...

  9. 分享知识-快乐自己:论Hibernate中的缓存机制

    Hibernate缓存 缓存: 是计算机领域的概念,它介于应用程序和永久性数据存储源之间. 缓存: 一般人的理解是在内存中的一块空间,可以将二级缓存配置到硬盘.用白话来说,就是一个存储数据的容器.我们 ...

随机推荐

  1. java.lang.IllegalArgumentException: System memory 259522560 must be at least 471859200.

    报错信息 java.lang.IllegalArgumentException: System memory 259522560 must be at least 471859200. Please ...

  2. eclipse中xml文件格式化

    eclipse中xml文件格式化(ctrl+shift+f),可能会发现格式化xml文件后很乱,如图: 这不是我想要的样子,我想要的是这样的: 解决办法:windows -> Perferenc ...

  3. Google AppCrawler初探

    AppCrawler是什么 你可以把它想成类似monkey一样的工具,调起你的应用程序并执行各种动作(点击,输入,滑动等)来通过这种方式 来查看各种情况下应用程序的状态 官方文档链接:AppCrawl ...

  4. C# 事件 Event

    一.事件是什么 微软的定义:和委托类似,事件是后期绑定机制. 实际上,事件是建立在对委托的语言支持之上的.事件是对象用于(向系统中的所有相关组件)广播已发生事情的一种方式. 任何其他组件都可以订阅事件 ...

  5. Spring 梳理 - WebMvcConfigurerAdapter详解

    参考:https://blog.csdn.net/weixin_43453386/article/details/83623242

  6. CentOS8-网卡配置

    一. 介绍 Centos8系统更新,新的版本让人看起来感觉很舒服,这时有人会配置CentOS8系统的网卡使系统上网,就会遇到配置好的网卡不会生效,自己想想和配置CentOS7的时候一个样啊,CentO ...

  7. 【ADO.NET--MVC】初学MVC(MVC入门)(1)

    最近一直在学MVC,本来今天想开始做项目了,但是一下手才发现还有好多好多都不懂,虽然想照搬别人的模板,但是还是觉得很虚,这也不懂哪也不懂.看来学习一门技术断不是那么简单,只要随便套套模板,看看别人代码 ...

  8. 搭建Nodejs环境 创建Express应用

    1. Nodejs Nodejs是一种服务器端js脚本运行环境: Nodejs框架是基于V8的引擎,是目前速度最快的Javascript引擎 2. Express开发框架 极简的web框架,完全是由路 ...

  9. Angular6 CodeMirror在线编辑sql 智能提示

    1. 安装ng2-codemirror包.codemirror包 npm install ng2-codemirror -- save npm install codemirror -- save 2 ...

  10. 品Spring:真没想到,三十步才能完成一个bean实例的创建

    在容器启动快完成时,会把所有的单例bean进行实例化,也可以叫做预先实例化. 这样做的好处之一是,可以及早地发现问题,及早的抛出异常,及早地解决掉. 本文就来看下整个的实例化过程.其实还是比较繁琐的. ...