- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
iBATIS缓存介绍
iBATIS缓存介绍 Mov,2010-01-18整理 一.缓存介绍 2 1.1缓存对象 2 1.2缓存介质[保存在哪里] 2 1.2.1内存 2 1.2.2硬盘 2 1.2.3数据库 2 1.3命中率 2 1.4最大保存元素数量 3 1.5缓存更新策略 3 1.5.1 FIFO[first in first out] 3 1.5.2 LFU[Less Frequently Used] 3 1.5.3 LRU[Least Recently Used] 3 1.6本地缓存VS远程缓存 3 二.iBATIS高速缓存介绍 4 2.1 iBATIS高速缓存的关注点 4 2.2 iBATIS对高速缓存管理的帮助 4 2.3 iBATIS高速缓存和传统O/RM高速缓存的区别 4 三. 配置iBATIS缓存 4 3.1 cacheModel标签 4 3.1.1 cacheModel标签的属性 4 3.1.2 联合使用readOnly和serialize属性 5 3.2 iBATIS高速缓存模型的类型 5 3.2.1 MEMORY 5 3.2.2 LRU 6 3.2.3 FIFO 6 3.2.4 OSCACHE 6 3.2.5自定义高速缓存模型 6 3.3 高速缓存的清除 7 3.4 设置高速缓存模式实现的特性 7 3.5 常见问题 7 3.5.1如何选择iBATIS高速缓存模型类型 7 3.5.2如何手工强制清除iBATIS高速缓存中保存的对象 8 3.5.3 OSCACHE基本使用及配置项说明 8 四. 参考资料 8 一.缓存介绍 1.1缓存对象 Http请求结果的缓存 浏览器缓存、代理缓存、服务器端方向代理缓存、使用Filter实现对请求结果页面的缓存 Java对象的缓存 缓存数据库查询结果对象 1.2缓存介质[保存在哪里] 从硬件介质上来将无非就是两种,内存和硬盘 对应应用层的程序来讲不用考虑寄存器等问题 .但是往往我们不会从硬件上来划分,一般的划分方法是从技术上划分,可以分成几种,内存,硬盘文件.数据库. 1.2.1内存 将缓存放在内存中是最快的选择,任何程序直接操作内存都比操作硬盘要快的多,但是如果你的数据要考虑到break down的问题,因为放在内存中的数据我们称之为没有持久话的数据,如果硬盘上没有备份,机器down机之后,很难或者无法恢复. 1.2.2硬盘 一般来说,很多缓存框架会结合使用内存和硬盘,比如给内存分配的空间有满了之后,会让用户选择把需要退出内存空间的数据持久化到硬盘.当然也选择直接把数据放一份到硬盘 内存中一份,硬盘中一份,down机也不怕 .也有其他的缓存是直接把数据放到硬盘上. 1.2.3数据库 说到数据库,可能有的人会想,之前不是讲到要减少数据库查询的次数,减少数据库计算的压力吗,现在怎么又用数据库作为缓存的介质了呢.这是因为数据库又很多种类型,比如berkleydb,这种db不支持sql语句,没有sql引擎,只是key和value的存储结构,所以速度非常的快,在当代一般的pc上,每秒中十几w次查询都是没有问题的. 1.3命中率 命中率是指请求缓存次数和缓存返回正确结果次数的比例.比例越高,就证明缓存的使用率越高. 命中率问题是缓存中的一个非常重要的问题,我们都希望自己缓存的命中率能达到100%,但是往往事与愿违,而且缓存命中率是衡量缓存有效性的重要指标. 1.4最大保存元素数量 缓存中可以存放得最大元素得数量,一旦缓存中元素数量超过这个值,那么将会起用缓存清空策略,根据不同的场景合理的设置最大元素值往往可以一定程度上提高缓存的命中率.从而更有效的时候缓存. 1.5缓存更新策略 1.5.1 FIFO[first in first out] 最先进入缓存得数据在缓存空间不够情况下 超出最大元素限制时 会被首先清理出去 1.5.2 LFU[Less Frequently Used] 一直以来最少被使用的元素会被被清理掉。这就要求缓存的元素有一个hit 属性,在缓存空间不够得情况下,hit 值最小的将会被清出缓存。 1.5.3 LRU[Least Recently Used] 最近最少使用的,缓存的元素有一个时间戳,当缓存容量满了,而又需要腾出地方来缓存新的元素的时候,那么现有缓存元素中时间戳离当前时间最远的元素将被清出缓存。 1.6本地缓存VS远程缓存 Local Cache:本地缓存 Remote Cache:远程缓存 Local Cache最大的优点是应用和Cache的时候是在同一个进程内部,请求缓存非常快速,完全不需要网络开销等.所以单应用,不需要集群或者集群情况下cache node不需要相互通知的情况下使用local cache比较合适. 但是Local cache是有一定的缺点
文档评论(0)