- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
ehcache详细介绍
目录1前言21.1背景21.2主要特性21.3使用注意点31.4使用场合31.5参考文献32基本配置32.1ehcache.XML32.2参数详解42.3hibernate.cfg.xml42.4配置相关实体的缓存策略53分布式缓存53.1RMI方式63.1.1设置自身63.1.2设置需要同步的对方服务器及缓存63.1.3缓存对象的配置73.1.4完整的配置文件(server1)83.1.5集群的作用93.2JGroups方式93.2.1配置PeerProvider,使用tcp的方式93.2.2为每个Cache添加cacheEventListener93.2.1完整的配置文件103.3JMS方式12前言背景系统缓存是位于应用程序与物理数据源之间,用于临时存放复制数据的内存区域,目的是为了减少应用程序对物理数据源访问的次数,从而提高应用程序的运行性能. 缓存设想内存是有限的,缓存的时效性也是有限的,所以可以设定内存数量的大小,可以执行失效算法 ,可以在内存满了的时候,按照最少访问等算法将缓存直接移除或切换到硬盘上。Ehcache从 Hibernate发展而来,逐渐涵盖了Cahce界的全部功能,是目前发展势头最好的一个项目。具有快速,简单,低消耗,依赖性小,扩展性强,支持对象或序列化缓存,支持缓存或元素的失效,提供LRU、LFU和FIFO缓存策略,支持内存缓存和磁盘缓存,分布式缓存机制等等特点。Cache 存储方式 :内存或磁盘。官方网站://主要特性快速. 2. 简单. 3. 多种缓存策略 4. 缓存数据有两级:内存和磁盘,因此无需担心容量问题 5. 缓存数据会在虚拟机重启的过程中写入磁盘 6. 可以通过RMI、可插入API等方式进行分布式缓存 7. 具有缓存和缓存管理器的侦听接口 8. 支持多缓存管理器实例,以及一个实例的多个缓存区域 9. 提供Hibernate的缓存实现使用注意点? 当用Hibernate的方式修改表数据(save,update,delete等等),这时EhCache会自动把缓存中关于此表的所有缓存全部删除掉(这样能达到同步)。但对于数据经常修改的表来说,可能就失去缓存的意义了(不能减轻数据库压力);使用场合比较少更新表数据 EhCache一般要使用在比较少执行write操作的表(包括update,insert,delete等)[Hibernate的二级缓存也都是这样];?对并发要求不是很严格的情况 两台机子中的缓存是不能实时同步的;参考文献ITeye论坛/category/127647?show_full=true/category/127647?show_full=true/blog/230252/blog/230252基本配置ehcache.XML<?xml version=1.0 encoding=UTF-8?> <ehcache> <diskStore path=Java.io.tmpdir/> <defaultCache maxElementsInMemory=10000 <!- 缓存最大数目 -> eternal=false <!- 缓存是否持久 -> overflowToDisk=true <!- 是否保存到磁盘,当系统当机时-> timeToIdleSeconds=300 <!- 当缓存闲置n秒后销毁 -> timeToLiveSeconds=180 <!- 当缓存存活n秒后销毁-> diskPersistent=false diskExpiryThreadIntervalSeconds= 120/> </ehcache> 参数详解eternal(必填项):如果为true,则永不过期,忽略后两个参数的设置。timeToIdleSeconds: 空闲无访问时间,默认为0,永不过时。timeToLiveSeconds: 空闲无访问时间,默认为0,永不过时。?移出算法:如果经过失效算法后,还是有很多有效的缓存,则执行清除算法。清除算法由两个参数组成:memoryStoreEvictionPolicy: 默认为LRU(最近最少访问),另有先进先出(FIFO),最少访问次数(LFU)overflowToDisk(必填项):为true,则将清除出来的缓存持久化到磁盘,否则销毁。maxElementsOnDisk:默认为0,无限多。存储到硬盘diskExpiryThreadIntervalSeconds:使用过期算法清除磁盘中失效对象的间隔,默认为120秒。?diskSpoolBufferSizeMB :默认为30M。diskPersistent :当应用重启时,可将缓存先持久化到硬盘,重启后再行载入,节省大量的重新从数据库载入。但只适合那些缓存不怎么变化,或者有特殊机制保证重启后应用能接收到重启这段时
文档评论(0)