您好,登录后才能下订单哦!
这篇文章主要介绍“Hibernate二级缓存的含义是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Hibernate二级缓存的含义是什么”文章能帮助大家解决问题。
Hibernate 二级缓存是 Hibernate 对象关系映射 (ORM) 库中可用的数据缓存组件之一。Hibernate 是一种流行的 Java 语言 ORM 库,它允许您将 Java 对象数据存储在关系数据库管理系统 (RDBMS) 中。
由于 Java 对象不会自然地与 RDBMS 的表/行/列对齐(这种现象称为“阻抗不匹配”),Hibernate 充当翻译层。使用 Hibernate,您可以通过提供从关系数据库表、行、列和外键到带注释的Java类映射机制,轻松快速地访问关系数据。Hibernate 使用易于使用的语法生成 SQL 查询,以基于 Java 面向对象的域模型查询数据。
二级缓存是通过插入第三方缓存技术来实现的,扩展Hibernate内置的缓存能力。它用于克服一级缓存的限制,如下所述。
缓存是Hibernate 框架的优势之一,它可以在多个级别上使用。
一级缓存是 Hibernate 检查缓存数据的第一个地方。默认情况下,它是内置的并处于活动状态,以减少直接对数据库的 SQL 查询数量。如果请求的查询结果不在一级缓存中,则针对底层数据库运行查询(即,如果没有启用二级缓存)。此缓存仅在会话级别起作用,这意味着每个会话对象都独立缓存数据,因此不会在会话之间共享缓存数据,并且在会话关闭时会删除缓存数据。这使得缓存仅对同一会话中的重复查询有用。对于跨多个会话的重复查询,这就是二级缓存发挥作用的地方。
使用 Hibernate 二级缓存,您可以插入缓存技术来补充一级缓存。如果请求的查询结果不在一级缓存中,则检查二级缓存。二级缓存跨会话共享缓存数据,因此所有会话/用户都可以从缓存数据中受益,即使对于由另一个会话插入的数据,即使将数据插入二级缓存的会话关闭。
二级缓存提高了使用同一会话工厂创建的所有会话的持久性方面的应用程序性能。使用二级缓存,即使请求是从多个会话执行的,缓存也可以为对象的请求提供服务,其延迟比请求发送到数据库时低得多。考虑到 ORM 查询可能很复杂,因此相对较慢,系统可以极大地受益于二级缓存,以减少对底层数据库的相同复杂/慢查询的重复。
这对于在对数据库进行 SQL 查询方面在用户之间具有高度共性的大容量 Web 应用程序特别有用。并且通过高度可扩展的缓存,您可以缓存更多的数据并实现更多的性能加速。
任何支持与 Hibernate 开箱即用集成的技术都可以插入以充当二级缓存。内存数据网格通常用作 Hibernate 二级缓存。例如,Hazelcast IMDG 内置了与 Hibernate 的集成,可以轻松插入二级缓存。借助其分布式架构,您可以向集群添加更多节点,以尽可能多地增加缓存,以处理更重的工作负载。
关于“Hibernate二级缓存的含义是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注亿速云行业资讯频道,小编每天都会为大家更新不同的知识点。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。