关于缓存的话题,在坛子里已经有很多讨论,简单的来说,如果一个应用中80% 的时间内都在访问20% 的数据,那么,这时候就应该使用缓存了。这个和长尾理论正好相悖,其实也不是相悖,只是不同的理论使用的场景不同。在80/20 原则生效的地方,我们都应该考虑是否可以使用缓存。但即使是这样,缓存也有不同的用法,举个例子,一个网站的首页估计是被访问的次数最多的,我们可以考虑给首页做一个页面缓存,而如果在某个页面上,比如说javaeye 的java 版区只有前几个页面是访问最频繁的,(假设javaeye 是使用hibernate ,当然这只是假设,我们都知道javaeye 是使用ror 开发的)那么我们就可以考虑给java 版区的record 做二级缓存了,因为二级缓存中是按照对象的id 来保存的,所以应该来说这前面几页使用的对象会一直存在于缓存之中(如何使用hibernate 的二级缓存坛子上也有介绍)。由此可见不同的页面的缓存策略有可能有天壤之别。
本文的目的就是上面所讲的两种情况之一,页面缓存。毫无疑问,几乎所有的网站的首页都是访问率最高的,而首页上的数据来源又是非常广泛的,大多数来自不同的对象,而且有可能来自不同的db ,所以给首页做缓存是一个不错的主意,那么主页的缓存策略是什么样子的呢,我认为应该是某个固定时间之内不变的,比如说2 分钟更新一次。那么这个缓存应该做在什么地方呢,让我们来看一下,假设您的应用的结构是page-filter-action-service-dao-db ,这个过程中的- 的地方都是可以做缓存的地方,根据页面缓存的特征,应该把页面缓存做到尽量靠近客户的地方,就是在page 和filter 之间,这样的优点就是第一个用户请求之后,页面被缓存,第二个用户再来请求的时候,走到filter 这个请求就结束了,无需再走后面的action-service-dao-db 。带来的好处是服务器压力的减低和客户段页面响应速度的加快。
那么我们来看一下如何使用ehcache 做到这一点。
在使用ehcache 的页面缓存之前,我们必须要了解ehcache 的几个概念,
1 timeToIdleSeconds ,多长时间不访问该缓存,那么ehcache 就会清除该缓存。
2 timeToLiveSeconds ,缓存的存活时间,从开始创建的时间算起。
看到这里,我们知道,首页的页面缓存的存活时间,我们定的是2 分钟,那么也就是说我们的timeToLiveSeconds 应该设置为120 ,同时我们的timeToIdleSeconds 最好也设置为2 分钟,或者小于2 分钟。我们来看一下下面这个配置,这个配置片段应该放到ehcache.xml 中:
< cache name = "SimplePageCachingFilter"
maxElementsInMemory = "10"
maxElementsOnDisk = "10"
eternal = "false"
overflowToDisk = "true"
diskSpoolBufferSizeMB = "20"
timeToIdleSeconds = "10"
timeToLiveSeconds = "10"
memoryStoreEvictionPolicy = "LFU"
/>
SimplePageCachingFilter 是缓存的名字,maxElementsInMemory 表示内存中SimplePageCachingFilter 缓存中元素的最大数量为10 ,maxElementsOnDisk 是指持久化该缓存的元素到硬盘上的最大数量也为10 (),eternal=false 意味着该缓存会死亡。overflowToDisk=true 意思是表示当缓存中元素的数量超过限制时,就把这些元素持久化到硬盘,如果overflowToDisk 是false ,那么maxElementsOnDisk 的设置就没有什么意义了。memoryStoreEvictionPolicy=LFU 是指按照缓存的hit 值来清除,也就是说缓存满了之后,新的对象需要缓存时,将会将缓存中hit 值最小的对象清除出缓存,给新的对象腾出地方来了(文章最后有ehcache 中自带的3 种缓存清空策略的介绍)。
接着我们来看一下SimplePageCachingFilter 的配置,
< filter >
< filter-name > indexCacheFilter filter-name >
< filter-class >
net.sf.ehcache.constructs.web.filter.SimplePageCachingFilter
filter-class >
filter >
< filter-mapping >
< filter-name > indexCacheFilter filter-name >
< url-pattern > *index.action url-pattern >
filter-mapping >
就只需要这么多步骤,我们就可以给某个页面做一个缓存的,把上面这段配置放到你的web.xml 中,那么当你打开首页的时候,你会发现,2 分钟才会有一堆sql 语句出现在控制台上。当然你也可以调成5 分钟,总之一切都在控制中。
好了,缓存整个页面看上去是非常的简单,甚至都不需要写一行代码,只需要几行配置就行了,够简单吧,虽然看上去简单,但是事实上内部实现却不简单哦,有兴趣的话,大家可以看看SimplePageCachingFilter 继承体系的源代码。
上面的配置针对的情况是缓存首页的全部,如果你只想缓存首页的部分内容时,你需要使用SimplePageFragmentCachingFilter 这个filter 。我们看一下如下片断:
< filter >
< filter-name > indexCacheFilter filter-name >
< filter-class >
net.sf.ehcache.constructs.web.filter.SimplePageFragmentCachingFilter
filter-class >
filter >
< filter-mapping >
< filter-name > indexCacheFilter filter-name >
< url-pattern > */index_right.jsp url-pattern >
filter-mapping >
这个jsp 需要被jsp:include 到其他页面,这样就做到的局部页面的缓存。这一点貌似没有oscache 的tag 好用。
事实上在cachefilter 中还有一个特性,就是gzip ,也就是说缓存中的元素是被压缩过的,如果客户浏览器支持压缩的话,filter 会直接返回压缩过的流,这样节省了带宽,把解压的工作交给了客户浏览器,如果客户的浏览器不支持gzip ,那么filter 会把缓存的元素拿出来解压后再返回给客户浏览器(大多数爬虫是不支持gzip 的,所以filter 也会解压后再返回流),这样做的优点是节省带宽,缺点就是增加了客户浏览器的负担(但是我觉得对当代的计算机而言,这个负担微乎其微)。
好了,如果你的页面正好也需要用到页面缓存,不防可以考虑一下ehcache ,因为它实在是非常简单,而且易用。
总结:ehcache 是一个非常轻量级的缓存实现,而且从1.2 之后就支持了集群,目前的最新版本是1.3 ,而且是hibernate 默认的缓存provider 。虽然本文是介绍的是ehcache 对页面缓存的支持,但是ehcache 的功能远不止如此,当然要使用好缓存,对JEE 中缓存的原理,使用范围,适用场景等等都需要有比较深刻的理解,这样才能用好缓存,用对缓存。
最后复习一下ehcache 中缓存的3 种清空策略:
1 FIFO ,first in first out ,这个是大家最熟的,先进先出,不多讲了
2 LFU , Less Frequently Used ,就是上面例子中使用的策略,直白一点就是讲一直以来最少被使用的。如上面所讲,缓存的元素有一个hit 属性,hit 值最小的将会被清出缓存。
2 LRU ,Least Recently Used ,最近最少使用的,缓存的元素有一个时间戳,当缓存容量满了,而又需要腾出地方来缓存新的元素的时候,那么现有缓存元素中时间戳离当前时间最远的元素将被清出缓存
分享到:
相关推荐
内容概要:本文详细介绍了Linux内核转储的概念、原理、配置与使用方法及其应用场景。内核转储是系统在异常时将内存状态和关键信息保存到文件中的机制,有助于故障排查、性能分析和程序异常处理。文章阐述了内核转储的重要性,包括在系统崩溃时提供“真相还原”,在程序异常时帮助“症结查找”,以及在性能瓶颈分析中作为“有力助手”。文中还深入剖析了内核转储的实现方式,如Kexec和Kdump机制,并详细讲解了配置相关工具(如kexec-tools、kdump、crash)的方法和步骤。最后,通过一个实际案例展示了内核转储在故障排查中的应用,以及未来的发展方向和技术趋势。 适合人群:具备一定Linux基础知识,从事Linux系统开发、运维的技术人员。 使用场景及目标:①在系统崩溃时,通过内核转储文件还原崩溃前的状态,找到问题根源;②在程序异常时,通过转储文件分析程序执行流程,定位异常原因;③在性能瓶颈分析中,通过转储文件了解系统资源使用情况,优化系统性能。 阅读建议:本文内容详尽,涵盖理论与实践操作,建议读者结合实际工作场景,逐步理解和掌握内核转储的配置与使用方法,并通过实际案例加深理解。
# 压缩文件中包含: 中文-英文对照文档 jar包下载地址 Maven依赖 Gradle依赖 源代码下载地址 # 本文件关键字: jar中文-英文对照文档.zip,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压最外层zip,再解压其中的zip包,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;
人工智能_多智能体系统_深度学习_计算机视觉_语音识别_语音合成_人脸识别_自然语言处理_基于Python的跨平台开发_Web界面设计_实时数据处理_分布式系统架构_面向人机交互的
内容概要:本文详细介绍了如何使用MATLAB和CPLEX进行冷热电多微网系统的双层优化配置。上层优化关注储能电站的容量配置,采用混合整数规划方法,考虑初始投资和运营成本;下层优化则处理各微网的能量调度,确保冷热电负荷平衡,并通过需求响应机制提高灵活性。文中还探讨了冷热电耦合、储能充放电管理以及跨层数据传递等关键技术点。通过仿真验证,共享储能模式相比独立储能可以显著降低综合成本,提升资源利用效率。 适用人群:适用于从事能源系统优化、智能电网研究的专业人士,尤其是熟悉MATLAB和CPLEX工具的研究人员和技术人员。 使用场景及目标:①帮助研究人员理解和掌握冷热电多微网系统的双层优化配置方法;②提供具体的代码实现案例,便于实际项目中的应用;③探索储能站在多微网系统中的最佳配置策略,以达到节能减排的目的。 其他说明:文章不仅提供了详细的理论推导和公式解释,还包括了丰富的代码片段,有助于读者更好地理解和实践相关技术。同时,针对可能出现的问题如求解时间过长、数据尺度不一致等给出了实用的解决方案。
内容概要:本文详细探讨了汇川IS620系列伺服驱动器的关键特性和源码原理,涵盖IS620N、IS620P等型号。文章介绍了多种通讯接口(RS-232、RS485、CAN)的应用实例,展示了刚性表设置、惯量识别及振动抑制等功能的具体实现方法。通过Python和C语言代码示例,解释了这些功能背后的复杂算法和控制逻辑,如惯量识别算法、振动抑制算法等。此外,还讨论了一些实用的调试技巧和注意事项,旨在帮助工程师更好地理解和应用这些高性能小功率交流伺服驱动器。 适合人群:从事自动化控制领域的工程师和技术人员,尤其是对伺服驱动器有兴趣的研究者。 使用场景及目标:适用于需要深入了解伺服驱动器内部工作机制的场合,如产品研发、系统集成、故障排查等。目标是提高工程师对IS620系列的理解,以便在其项目中充分利用这些驱动器的优势。 其他说明:文中提供了丰富的代码示例和实践经验分享,有助于读者快速掌握相关技术和解决实际问题。同时提醒读者注意一些潜在的技术陷阱,如通讯接口配置中的细节问题。
chromedriver-win32-138.0.7153.0.zip
helpcode_chat-room_12888_1745869959312
# 压缩文件中包含: 中文文档 jar包下载地址 Maven依赖 Gradle依赖 源代码下载地址 # 本文件关键字: jar中文文档.zip,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压最外层zip,再解压其中的zip包,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;
内容概要:本文深入探讨了在Matlab中实现永磁同步电机(PMSM)直接转矩控制(DTC)的方法和技术细节。首先介绍了PMSM的基本模型搭建,包括关键参数设置和状态空间方程的构建。接下来详细解析了DTC的核心原理及其具体实现步骤,如转矩和磁链的滞环控制机制、电压矢量的选择策略等。此外,文中还分享了许多实用的经验和技巧,例如如何调整滞环宽度、优化磁链观测器以及解决常见的仿真问题。同时强调了Matlab官方文档的重要性和持续跟进最新版本的价值。 适合人群:从事电机控制系统研究与开发的技术人员,尤其是有一定Matlab基础并希望深入了解PMSM DTC实现的人群。 使用场景及目标:适用于需要快速响应、高精度控制的场合,如工业自动化设备、电动汽车等领域。通过掌握本文提供的技术和方法,能够提高系统的稳定性和效率,降低开发难度。 其他说明:文中提供了大量详细的代码片段和参数配置建议,有助于读者更好地理解和应用所介绍的内容。同时也提醒读者注意实际操作过程中可能出现的问题及解决方案。
# 压缩文件中包含: 中文文档 jar包下载地址 Maven依赖 Gradle依赖 源代码下载地址 # 本文件关键字: jar中文文档.zip,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压最外层zip,再解压其中的zip包,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;
内容概要:本文详细介绍了基于MATLAB实现的电热综合能源市场双层出清模型,重点探讨了能源集线器在电热市场中的角色及其优化策略。模型分为上下两层,上层旨在最大化能源集线器的收益,涉及电价和热价的决策变量;下层则分别构建了电力市场最小发电成本模型和热力市场最小出力模型,确保市场出清。文中不仅展示了具体的MATLAB代码实现,还讨论了模型的创新点和技术细节,如MPEC方法的应用、CPLEX求解器的使用以及KKT条件的转化。此外,文章还提供了详细的调试经验和优化技巧,帮助读者更好地理解和应用该模型。 适合人群:从事综合能源系统研究的技术人员、研究生及以上学历的研究者。 使用场景及目标:适用于需要深入了解电热综合能源市场运作机制的研究人员,尤其是关注能源集线器在市场中的优化策略和市场均衡的人群。目标是通过该模型的学习,掌握双层优化模型的构建方法及其在实际能源市场中的应用。 其他说明:文章提供了丰富的代码片段和调试建议,有助于读者在实践中逐步掌握模型的构建和优化过程。同时,文章还指出了未来可能的改进方向,如引入更多能源种类和考虑网络阻塞等问题。
内容概要:本文介绍了如何使用MATLAB结合CPLEX求解器进行微电网调度优化的两个经典案例。案例一关注于常规发电机组的启停和出力优化,旨在满足系统负荷需求的同时实现成本最优。案例二则涉及燃气轮机、风力发电、光伏发电以及蓄电池等多种设备的协同优化,目标是最小化总费用。文中提供了详细的代码实现步骤,包括参数定义、模型初始化、决策变量定义、目标函数设定、约束条件构建以及最终的求解与结果输出。此外,还分享了一些实用技巧和避坑指南。 适合人群:对微电网调度优化感兴趣的科研人员、工程师和技术爱好者,尤其是有一定MATLAB基础的新手。 使用场景及目标:适用于希望深入了解微电网调度优化原理及其实际应用的人群。通过学习这两个案例,读者可以掌握如何利用MATLAB和CPLEX快速搭建优化模型,并应用于实际工程项目中,提高能源利用效率,降低运营成本。 其他说明:文中提供的代码均为简化版本,便于理解和修改。实际应用时可根据具体情况调整参数和增加更多复杂的约束条件。
内容概要:本文详细介绍了基于MATLAB实现的增强型鲸鱼优化算法(EWOA),主要改进之处在于引入了非线性时变自适应权重、差分变异微扰因子以及改进的对数螺旋搜索方式。这些改进显著提高了算法在全球探索和局部寻优方面的性能。文章不仅解释了每个改进部分的工作原理,还提供了相应的MATLAB代码示例,帮助读者理解和应用这些创新点。具体来说,非线性时变自适应权重使得算法能够在不同的搜索阶段灵活调整搜索策略;差分变异微扰因子避免了算法过早收敛到局部最优解;改进的对数螺旋搜索方式增强了算法的遍历能力。 适合人群:对优化算法感兴趣的科研人员、研究生以及从事相关领域的工程师。 使用场景及目标:适用于解决复杂的多维优化问题,如电力系统调度、无人机路径规划等。目标是提高优化算法的效率和准确性,特别是在高维复杂问题中寻找全局最优解。 其他说明:文中提供的MATLAB代码可以直接运行,并且可以根据具体应用场景调整参数。需要注意的是,种群规模不宜过大,以免增加计算负担。此外,文中提到的一些改进措施,如拉丁超立方采样初始化、变异因子的自适应调整等,对于提高算法性能至关重要。
内容概要:本文介绍了使用宽度优先搜索(BFS)解决一个名为“数字交换游戏”的编程问题。游戏规则为:给定一个M位的整数,通过最多K次任意两位数字的交换,在不产生前导零的情况下,求出能获得的最大整数。文中提供了具体的算法实现,包括输入输出示例以及对特殊情况的处理,如无法通过交换获得更大数值时输出-1。此外,还展示了部分代码片段,用于演示如何利用字符串操作实现数字字符之间的比较与交换,从而完成整个搜索过程。; 适合人群:对算法设计有兴趣的初学者,特别是正在学习或复习BFS算法及其应用的学生或程序员。; 使用场景及目标:①理解宽度优先搜索算法的应用场景和实现方式;②掌握基于字符串处理的数字交换逻辑;③学会处理边界条件,如避免产生前导零等特殊情况。; 阅读建议:读者可以先尝试自己解决这个问题,再对照文中的代码和思路进行对比学习,注意关注代码中对于边界情况的处理方法,这对于提高编程能力非常有帮助。同时,也可以将此题作为练习BFS算法的一个实例,深入理解其工作原理。
scratch少儿编程逻辑思维游戏源码-还未开发完的游戏.zip
内容概要:本文详细介绍了Linux ALG网关的功能及其在网络中的重要性。文章首先描述了网络不给力的常见场景,如视频卡顿、文件传输失败等,引出了NAT和防火墙对多通道协议的限制问题。接着,文章重点阐述了Linux ALG网关作为应用层网关,如何通过解析和处理应用层协议(如FTP、SIP等)中的地址和端口信息,动态创建“pinhole”来解决这些问题,确保数据传输顺畅。Linux ALG网关不仅能增强网络安全性,防范SQL注入、XSS攻击等,还能提升网络兼容性,支持多通道协议的正常通信。最后,文章探讨了ALG网关在企业网络、数据中心和家庭网络中的应用场景,并展望了其在物联网、5G网络和人工智能领域的未来发展潜力。 适合人群:对网络安全有一定了解,希望深入了解Linux ALG网关工作原理及应用场景的IT从业人员和技术爱好者。 使用场景及目标:①了解Linux ALG网关如何解决多通道协议在网络传输中的问题;②掌握ALG网关在企业网络边界防护、数据中心安全保障和家庭网络安全守护中的具体应用;③探索ALG网关在物联网、5G网络和人工智能等新兴技术领域的发展前景。 其他说明:配置Linux ALG网关需要一定的Linux系统操作基础,建议读者在实践中逐步熟悉iptables或firewalld等工具的使用,并注意规则顺序、性能优化和安全策略的制定,以确保网络的高效、安全运行。
机器人感知与导航_ROS点云数据处理_Livox雷达CustomMsg转PointCloud2格式转换工具_用于将大疆览沃Livox雷达驱动程序发布的CustomMsg格式点云数据
# 压缩文件中包含: 中文-英文对照文档 jar包下载地址 Maven依赖 Gradle依赖 源代码下载地址 # 本文件关键字: jar中文-英文对照文档.zip,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压最外层zip,再解压其中的zip包,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;
# 压缩文件中包含: 中文-英文对照文档 jar包下载地址 Maven依赖 Gradle依赖 源代码下载地址 # 本文件关键字: jar中文-英文对照文档.zip,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压最外层zip,再解压其中的zip包,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;
# 压缩文件中包含: 中文文档 jar包下载地址 Maven依赖 Gradle依赖 源代码下载地址 # 本文件关键字: jar中文文档.zip,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压最外层zip,再解压其中的zip包,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;