美文网首页
查询缓存(第三讲)

查询缓存(第三讲)

作者: 辽A丶孙悟空 | 来源:发表于2020-07-28 15:20 被阅读0次
ehcache 二级查询缓存

MyBatis 的特长是 SQL 操作,缓存数据管理不是其特长,为了提高缓存的性能,MyBatis 允许使用第三方缓存产品。ehCache 就是其中的一种。
项目:MyBatis_SecondLevel_ehCache。在上一个项目的基础上进行修改即可。
注意,使用 ehcache 二级缓存,实体类无需实现序列化接口。

  • 导入 Jar 包
    这里需要两个 Jar 包:一个是 ehcache 的核心 Jar 包,一个是与 MyBatis 整合的插件 Jar 包。他们可以从https://github.com/mybatis/ehcache-cache/releases下载。

    解压缩文件,获取到它们。其中 lib 下的是 ehcache 的核心 Jar 包。
  • 添加 ehcache.xml
    解压EHCache的核心Jar包ehcache-core-2.6.8.jar,将其中的一个配置文件
    ehcache- failsafe.xml直接放到项目的src目录下,并更名为ehcache.xml。

    (1)<diskStore/>标签
    指定一个文件目录,当内存空间不够,需要将二级缓存中数据写到硬盘上时,会写到这个指定目录中。其值一般为 java.io.tmpdi,表示当前系统的默认文件临时目录。

    当前系统的默认文件临时目录,可以通过 System.property() 方法查看:

    (2)<defaultCache/>标签

    设定缓存的默认属性数据:
    ① maxElementsInMemory:指定该内存缓存区可以存放缓存对象的最多个数。
    ② eternal:设定缓存对象是否不会过期。若设为 true,表示对象永远不会过期,此时会忽略 timeToldleSeconds 与 timeToLiveSeconds 属性。默认值为 false。
    ③ timeToldleSeconds:设定允许对象处于空闲状态的最长时间,以秒为单位。当对象自从最近一次被访问后,若处于空闲状态的时间超过了 timeToldleSeconds 设定的值,这个对象就会过期。当对象过期,EHCache 就会将它从缓存中清除。设置值为0,则对象可以无限期地处于空闲状态。
    ④ timeToLiveSeconds:设定对象允许存在于缓存中的最长时间,以秒为单位。当对象自从被存放到缓存后,若处于缓存中的时间超过了 timeToLiveSeconds 设定的值,这个对象就会过期。当对象过期,EHCache 就会将它从缓存中清除。设置值为0,则对象可以无限期地存在于缓存中。注意,只有 timeToLiveSeconds ≥ timeToldleSeconds,才有意义。
    ⑤ overflowToDisk:设定为 true,表示当缓存对象达到了 maxElementsInMemory 界限,会将溢出的对象写到<diskStore>元素指定的硬盘日录缓存中。
    ⑥ maxElementsOnDisk:指定硬盘缓存区可以存放缓存对象的最多个数。
    ⑦ diskPersistent:指定当程序结束时,硬盘缓存区中的缓存对象是否做持久化。
    ⑧ diskExpiryThreadIntervalSeconds:指定硬盘中缓存对象的失效时间间隔。
    ⑨ memoryStoreEvictionPolicy: 如果内存缓存区超过限制,选择移向硬盘缓存区中的
    对象时使用的策略。支持三种策略:
    FIFO:First In First Out,先进先出
    LFU:Less Frequently Used,最少使用
    LRU:Least Recently Used,最近最少使用
  • 启用 ehcache 缓存机制
    在映射文件的 mapper 中的<cache/>中通过 type 指定缓存机制为 Ehcache 缓存。默认为 myBatis 内置的二级缓存 org.apache.ibatis.cache.impl.PerpetualCache。



    该类在 mybatis-ehcache 的 jar 包中可以找到。


  • ehcache 在不同 mapper 中的个性化设置
    在 ehcache.xml 中设置的属性值,会对该项目中所有使用 ehcache 缓存机制的缓存区域起作用。一个项目中可以有多个 mapper,不同的 mapper 有不同的缓存区域。对于不同缓存区域也可进行专门针对于当前区域的个性化设置,可通过指定不同 mapper 的<cache>属性值来设置。
    <cache>属性值的优先级高于ehcache.xml中的属性值。


相关文章

  • Hibernate @Cache 注解

    本文主要摘自Hibernate缓存,整理些要点出来 Hibernate查询缓存依赖于二级缓存。当启用查询缓存后,第...

  • 查询缓存(第三讲)

    ehcache 二级查询缓存 MyBatis 的特长是 SQL 操作,缓存数据管理不是其特长,为了提高缓存的性能,...

  • MySQL学习——查询缓存

    MySQL查询缓存简介 MySQL查询缓存是MySQL将查询返回的完整结果保存在缓存中。当查询命中该缓存,MySQ...

  • Mysql - 一条sql语句是如何执行的

    1. 连接器 长连接保持通信 2. 查询缓存 每次查询都会缓存查询结果,相同语句再次查询时直接返回缓存结果,缓存结...

  • Yii2缓存组件之数据库查询缓存

    查询缓存 查询缓存是一个建立在数据缓存之上的特殊缓存特性。它用于缓存数据库查询的结果。(PS需配置好缓存配置) 查...

  • 查询缓存

    查询缓存原理 mysql查询缓存保存完整的查询结果,当查询命中缓存时,立刻返回结果,跳过了解析,优化和执行阶段。 ...

  • MySQL数据库性能优化

    MySQL架构 查询缓存 查询缓存(Query Cache)原理: 缓存SELECT操作或预处理查询的结果集和SQ...

  • 5. 查询缓存和索引

    1. 查询缓存 查询缓存( Query Cache )原理缓存SELECT操作或预处理查询的结果集和SQL语句,...

  • Mysql 查询优化

    如果查询缓存有命中的查询结果,查询语句就可以直接去查询缓存中取数据。缓存在第一次查询后,MySQL便将查询语句以及...

  • (8)MySQL性能优化的最佳21条经验(未完待续)

    1.为查询缓存优化你的查询 某些查询语句会让MySQL不使用缓存。 MySQL的查询缓存对这个函数不起作用。像...

网友评论

      本文标题:查询缓存(第三讲)

      本文链接:https://www.haomeiwen.com/subject/wlrtrktx.html