使用Redis在Hibernate中进行缓存
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中进行缓存相关推荐
- redis 实际应用中的缓存作用
redis 实际应用中的缓存作用 有人说互联网用户是用脚投票的,这句话其实也从侧面说明了,用户体验是多么的重要:这就要求在软件架构设计时,不但要注重可靠性.安全性.可扩展性以及可维护性等等的一些指标, ...
- java中一级缓存_JavaWeb_(Hibernate框架)Hibernate中一级缓存
Hibernate中一级缓存 Hibernate 中的缓存分为一级缓存和二级缓存,这两个级别的缓存都位于持久化层,并且存储的都是数据库数据的备份.其中一级缓存是 Hibernate 的内置缓存,在前面 ...
- redis作为hibernate的二级缓存
hibernate的二级缓存有好多,像ehcache.不过项目的缓存使用的是redis,而redis官方没有实现hibernate的二级缓存接口,只得自己实现.看看公司的高手如何做的吧. 先看配置: ...
- Hibernate中二级缓存配置
实体类 : 1 package cn.happy.entity; 2 public class Emp { 3 private Integer empNo; 4 private String empN ...
- Hibernate中的三种数据持久状态和缓存机制
Java三大框架之--Hibernate中的三种数据持久状态和缓存机制 Hibernate中的三种状态 瞬时状态:刚创建的对象还没有被Session持久化.缓存中不存在这个对象的数据并且数据库中没 ...
- Redis在项目中的使用及性能测试
强烈推荐一个大神的人工智能的教程:http://www.captainbed.net/zhanghan [前言] 在上篇博文中为大家分享了<SCPPO:C#中Redis封装的类>,有了这个 ...
- Spring Boot中的缓存支持(二)使用Redis做集中式缓存
上一篇介绍了在Spring Boot中如何引入缓存.缓存注解的使用.以及EhCache的整合. 虽然EhCache已经能够适用很多应用场景,但是由于EhCache是进程内的缓存框架,在集群模式下时,各 ...
- EhCache 是一个纯Java的进程内缓存框架,具有快速、精干等特点,是hibernate中默认的CacheProvider Ehcache是一种广泛使用的开源Java分布式缓存。主要面向通
EhCache 是一个纯Java的进程内缓存框架,具有快速.精干等特点,是hibernate中默认的CacheProvider Ehcache是一种广泛使用的开源Java分布式缓存.主要面向通用缓存, ...
- 在Spring、Hibernate中使用Ehcache缓存
前一篇http://blog.csdn.net/ibm_hoojo/article/details/7739181介绍了Ehcache整合Spring缓存,使用页面.对象缓存:这里将介绍在Hibern ...
最新文章
- NHibenate 一些自带增删改查
- shell脚本操作mysql数据库,使用mysql的-e参数可以执行各种sql的(创建,删除,增,删,改、查)等各种操作
- CTAssetsPickerController 选中图片不显示对号的问题解决
- 3.2Python的循环结构语句:
- C# 生成缩略图 方法
- python技术是什么意思_python中“//”表示什么意思_后端开发
- Stop Googling!
- 面试官问我:如何在 Python 中解析和修改 XML
- C#事件-趣谈事件与委托
- leetcode 14 最长公共前缀(python)
- linux java 栈_JVM 与 Linux 的内存关系详解
- SQL - 插入数据
- JavaScript入门知识
- Linux安装显卡驱动后闪屏问题
- zip压缩脚本(linux)
- 启动kafka时报错:java.nio.file.FileSystemException,另一个程序正在使用此文件,进程无法访问。
- LeetCode #1056. Confusing Number
- 幼儿园计算机基础知识培训总结,幼儿园园本培训工作总结
- Linux移植EC20 4G模块驱动简易教程
- 【成长访谈】周新林:靠持续的努力,总能换来自己期望的生活