Hibernate缓存机制

 我来答
大沈他次苹0B
2022-10-20 · TA获得超过7347个赞
知道大有可为答主
回答量:3059
采纳率:100%
帮助的人:180万
展开全部

  缓存是位于应用程序与物理数据源之间 用于临时存放复制数据的内存区域 目的是为了减少应用程序对物理数据源访问的次数 从而提高应用程序的运行性能

  Hibernate在查询数据时 首先到缓存中去查找 如果找到就直接使用 找不到的时候就会从物理数据源中检索 所以 把频繁使用的数据加载到缓存区后 就可以大大减少应用程序对物理数据源的访问 使得程序的运行性能明显的提升

  Hibernate缓存分类

  Session缓存 一级缓存

  SessionFactory的缓存分为内置缓存和外置缓存 内置缓存中存放的是SessionFactory对象的一些集合属性包含的数据(映射元素据及预定义SQL语句等) 对于应用程序来说 它是只读的 外置缓存中存放的是数据库数据的副本 其作用和一级缓存类似 二级缓存除了以内存作为存储介质外 还可以选用硬盘等外部存储设备

  Hibernate的缓存范围

  Hibernate的一级缓存和二级缓存都位于均位于持久层 且均用于存放数据库数据的副本 最大的区别就是缓存的范围各不一样

  缓存的范围分为 类:

   事务范围

  事务范围的缓存只能被当前事务访问 每个事务都有各自的缓存 缓存内的数据通常采用相互关联的对象形式 缓存的生命周期依赖于事务的生命周期 只有当事务结束时 缓存的生命周期才会结束 事务范围的缓存使用内存作为存储介质 一级缓存就属于事务范围

   应用范围

  应用程序的缓存可以被应用范围内的所有事务共享访问 缓存的生命周期依赖于应用的生命周期 只有当应用结束时 缓存的生命周期才会结束 应用范围的缓存可以使用内存或硬盘作为存储介质 二级缓存就属于应用范围

   集群范围

  在集群环境中 缓存被一个机器或多个机器的进程共享 缓存中的数据被复制到集群环境中的每个进程节点 进程间通过远程通信来保证缓存中的数据的一致 缓存中的数据通常采用对象的松散数据形式

  Hibernate的缓存管理

  一级缓存的管理:

  evit(Object obj) 将指定的持久化对象从一级缓存中清除 释放对象所占用的内存资源 指定对象从持久化状态变为脱管状态 从而成为游离对象

  clear() 将一级缓存中的所有持久化对象清除 释放其占用的内存资源

  contains(Object obj) 判断指定的对象是否存在于一级缓存中

  flush() 刷新一级缓存区的内容 使之与数据库数据保持同步

  二级缓存的管理:

  evict(Class arg Serializable arg ) 将某个类的指定ID的持久化对象从二级缓存中清除 释放对象所占用的资源

  Java代码

  sessionFactory evict(Customer class new Integer( ));

  evict(Class arg ) 将指定类的所有持久化对象从二级缓存中清除 释放其占用的内存资源

  Java代码

  sessionFactory evict(Customer class);

  evictCollection(String arg ) 将指定类的所有持久化对象的指定集合从二级缓存中清除 释放其占用的内存资源

  Java代码

  sessionFactory evictCollection( Customer orders );

  Hibernate的二级缓存的配置

  首先 不是所有的数据都适合放在二级缓存中 看一下 什么样的数据适合放在二级缓存中来?什么样的数据不适合放在二级缓存中来?

  下面这几种情况就不适合加载到二级缓存中:

   经常被修改的数据

   绝对不允许出现并发访问的数据

   与其他应用共享的数据

  下面这己种情况合适加载到二级缓存中:

   数据更新频率低

   允许偶尔出现并发问题的非重要数据

   不会被并发访问的数据

   常量数据

   不会被第三方修改的数据

  Hibernate的二级缓存功能是靠配置二级缓存插件来实现的 Hibernate为了集成这些插件 Hibernate提供了 hibernate cache CacheProvider借口 它充当缓存插件与Hibernate之间的适配器

  常用的二级缓存插件

  EHCache hibernate cache EhCacheProvider

  OSCache hibernate cache OSCacheProvider

  SwarmCahe hibernate cache SwarmCacheProvider

  JBossCache hibernate cache TreeCacheProvider

  简单介绍一下EHCache的配置

  hibernate cfg xml

  Xml代码

  <hibernate configuration>

  <session factory>

  <! 设置二级缓存插件EHCache的Provider类 >

  <property name= hibernate cache provider_class >

   hibernate cache EhCacheProvider

  </property>

  <! 启动 查询缓存 >

  <property name= hibernate cache use_query_cache >

  true

  </property>

  </session factory>

  </hibernate configuration>

  ehcache xml

  Xml代码

  <ehcache>

  <! maxElementsInMemory为缓存对象的最大数目 eternal设置是否永远不过期 timeToIdleSeconds对象处于空闲状态的最多秒数 timeToLiveSeconds对象处于缓存状态的最多秒数 >

  <diskStore path= java io tmpdir />

  <defaultCache maxElementsInMemory= eternal= false   timeToIdleSeconds= timeToLiveSeconds= overflowToDisk= true />

  </ehcache>

  **** hbm xml

  Xml代码

  <?xml version= encoding= UTF ?>

  <!DOCTYPE hibernate mapping PUBLIC

   //Hibernate/Hibernate Mapping DTD //EN

   mapping dtd >

  <hibernate mapping>

  <class>

  <! 设置该持久化类的二级缓存并发访问策略 read only read write nonstrict read write transactional >

  <cache usage= read write />

  </class>

lishixinzhi/Article/program/Java/ky/201311/28418

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
Storm代理
2023-08-29 广告
"StormProxies是全球大数据IP资源服务商,其住宅代理网络由真实的家庭住宅IP组成,可为企业或个人提供满足各种场景的代理产品。点击免费测试(注册即送1G流量)StormProxies有哪些优势?1、IP+端口提取形式,不限带宽,I... 点击进入详情页
本回答由Storm代理提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式