应用程序缓存包括:对象缓存、查询缓存、页面缓存
页面缓存包括:动态页面静态化、servlet缓存、页面内部缓存
对象缓存
由hibernate框架提供,细粒度的缓存数据库的查询结果,无需手动编码实现,(也可以不实用hibernate,而是自己实现对象缓存如将查询出的对象放入hashMap中等),是最省事的缓存策略,使用对象缓存会极大的降低web系统对数据库的访问量。
对象缓存适合联机事务处理(OLTP)
对象缓存分为:对表记录的entity对象缓存、对1n关系集合的缓存、对n对1关系关联对象的缓存。
hibernate对象缓存的配置
@Entity
@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
public class Forest { ... }
注:NonstrictReadWriteCache
Caches data that is sometimes updated without ever locking the cache. If concurrent access to an item is possible, this concurrency strategy makes no guarantee that the item returned from the cache is the latest version available in the database. Configure your cache timeout accordingly! This is an "asynchronous" concurrency strategy.
有时更新缓存数据时无需锁住该缓存,如果可能对一个项目进行并发性的访问,那么这种并发的策略使得缓存返回数据库最新版本数据无法得到保证。这个是一个异步的缓存策略。
配置关联集合的缓存
@OneToMany(cascade=CascadeType.ALL, fetch=FetchType.EAGER)
@JoinColumn(name="CUST_ID")
@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
public SortedSet<Ticket> getTickets() { return tickets; }
注:在返回一所关联的多个对象上添加异步缓存的注解
仅仅添加Annotation就可以了,无须编码,即可自动享受对象缓存。Hibernate会拦截对象的CRUD操作,针对对象读取操作进行缓存,针对对象修改操作自动清理缓存
Hibernate二级缓存
Hibernate二级缓存是提升web应用性能的法宝,OLTP类型的web应用,由于应用服务器端可以进行群集水平扩展,最终的系统瓶颈总是逃不开数据库访问;
哪个框架能够最大限度减少数据库访问,降低数据库访问压力,哪个框架提供的性能就更高;
针对数据库的缓存策略:对象缓存、查询缓存、应用于数据时时话不高的情况。
查询缓存是对查询结果进行缓存,类似数据库的Query Cache,适用于一些耗时,但是时时性要求不高的情景。查询缓存和对象缓存是互补的。
当查询结果集涉及到的记录表被修改后需要注意清理缓存。
配置hibernate的查询缓存
在配置文件中打开Query Cache
hibernate.cache.use_query_cache true
在查询的时候显式编码使用Cache
List blogs = sess.createQuery("from Blog blog where blog.blogger = :blogger") .setEntity("blogger",blogger) .
setMaxResults(15) .
setCacheable(true) .
setCacheRegion("frontpages") .
list();
Hibernate查询缓存特征
并非缓存整个查询结果集,而是缓存查询结果集的entity对象id。
entity对象的id集合
[blogId1, blogId2, blogId3,…]
在遍历结果集的时候,再按照blogId去查询blog对象,例如 select blog.* from blog where id=?
如果此时blog配置了对象缓存,则自动读取对象缓存
Hibernate查询缓存会自动清理过期缓存
一旦结果集涉及的entity被修改,查询缓存就被自动清理
页面缓存
页面缓存的作用是什么?
1.针对页面的缓存技术不但可以减轻数据库服务器压力,还可以减轻应用服务器压力
2.好的页面缓存可以极大提高页面渲染速度
3.页面缓存的难点在于如何清理过期的缓存
页面缓存技术有哪些?
1.动态页面静态化
2.Servlet缓存
3.页面局部缓存
动态页面静态化
利用模版技术将访问过的动态页面生产静态的html,同时修改链接,下一次请求直接访问静态链接页面。
动态页面静态化技术的广泛应用于互联网CMS/新闻类Web应用,但也有BBS应用使用该技术,例如Discuz!
缺点:
无法进行权限验证,无法显示个性化信息
可以使用AJAX请求弥补动态页面静态化的某些缺点
Servlet缓存
针对URL访问
返回的页面结果进行缓存,适用于粗粒度的页面缓存,例如新闻发布
OScache提供了简单的Servlet缓存(通过web.xml中的配置)
也可以自己编程实现Servlet缓存
实例
<filter>
<filter-name>CacheFilter</filter-name>
<filter-class>com.opensymphony.oscache.web.filter.CacheFilter</filter-class>
<init-param>
<param-name>time</param-name>
<param-value>600</param-value>
</init-param>
<init-param>
<param-name>scope</param-name>
<param-value>session</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>CacheFilter</filter-name>
<url-pattern>/news/*</url-pattern>
</filter-mapping>
页面局部缓存
针对动态页面的局部片断内容进行缓存,适用于一些个性化但不经常更新的页面(例如博客)
OSCache提供了简单的页面缓存
可以自行扩展JSP Tag实现页面局部缓存
实例:
<%@ taglib uri="http://www.opensymphony.com/oscache" prefix="cache" %>
<cache:cache>
... some jsp content ...
</cache:cache>
<cache:cache key="foobar" scope="session">
... some jsp content ...
</cache:cache>
<cache:cache key="<%= product.getId() %>" time="1800" refresh="<%= needRefresh %>">
... some jsp content ...
</cache:cache>
<cache:cache key="<%= product.getId() %>" cron="0 2 * * *" refresh="<%= needRefresh %>">
... some jsp content ...
</cache:cache>
EHCache
适合充当对象缓存和Hibernate集成效果很好,Gavin King也是EHCache作者之一
OSCache
充当Servlet和页面缓存
在一个Web应用当中可以同时使用OSCache和EHCache
JBossCache
在Java群集环境下使用
支持缓存在节点之间的复制,在JBoss AS上被用来实现HTTP Session的内存复制功能
非Java实现的通用缓存产品
Memcached
在大规模互联网应用下使用
每秒支撑1.5万~2万次请求
Tokyo Tyrant
兼容memcached协议,可以持久化存储
支持故障切换,对缓存服务器有高可靠性要求可以使用
每秒支撑0.5万~0.8万次请求
基于AJAX技术的浏览器缓存
使用AJAX调用的时候,将数据库在浏览器端缓存
只要不离开当前页面,不刷新当前页面,就可以直接读取缓存数据
只适用于使用AJAX技术的页面
未使用ajax缓存代码
<script src="jQuery.js"></script>
2. <script language="JavaScript">
3. <!--
4. function gopage(option,obj){
5. var page = $("#page").html() * 1;
6. obj.disabled = true;
7. if(option == '+'){
8. page ++ ;
9. var url = "data.php?page="+page + "&r="+Math.random();//使用ajax要加上时间戳或是随机数,如Math.random()或是new Date()
10. //获取ajax url,后面的random是为了防止浏览器缓存xml内容
11. }else{
12. page --;
13. if(page < 1)page =1;
14. var url = "data.php?page="+page + "&r="+Math.random();
15.
16. }
17. $("#data").html("loading...");//设置loading状态
18. $("#page").html(page);
19. //下面是ajax处理
20. $("#data").load(url,
21. {limit: 25}, //此处为传递给服务器端的参数
22. function() { obj.disabled = false; }
23. );
24.
25. }
26. //-->
27. </script>
28. <input value="<" onclick="gopage('-',this)" type="button">//传递this不需要加''
29. <input value=">" onclick="gopage('+',this)" type="button">
30. page:<span id="page">1</span>
31. <div style="border: 2px solid red; padding: 2px;" id="data">data area</div>
注:load方法默认为get方式,当传递数据时使用post方式。
使用ajax的缓存代码# <script language="JavaScript">
# <!--
# var cache_data = new Array();//定义全局变量用来保存缓存数据
//使用new Array定义全局的数组
# function gopageCache(option,obj){
# var page = $("#page2").html() * 1;
# if(option == '+'){
# page ++ ;
# var url = "data.php?page="+page + "&r="+Math.random();
# }else{
# page --;
# if(page < 1)page =1;
# var url = "data.php?page="+page + "&r="+Math.random();
#
# }
# /*下面是缓存增加的部分*/
//先从缓存中查找
# if( (cache_data[page] !=null) && (cache_data[page].length > 1) ) {
# //如果缓存存在,则直接调用缓存数据,不用再去服务器进行数据请求
# alert('cache hit');
# $("#data2").html(cache_data[page]);
# $("#page2").html(page);
# return true;
# }
# $("#page2").html(page);
# obj.disabled = true;
# $("#data2").html("loading(cache enabled)...");
# $("#data2").load(url,
# {limit: 25}, //逐条缓存的
# function(responseText) { obj.disabled = false;
# cache_data[page] = responseText;//将当前的数据存入到内存(缓存变量)中 }
# );
#
# }
#
# //-->
# </script>
# <input value="<" onclick="gopageCache('-',this)" type="button">
# <input value=">" onclick="gopageCache('+',this)" type="button">
# page:<span id="page2">1</span>
# <div style="border: 2px solid red; padding: 2px;" id="data2">data area</div>
基于HTTP协议的资源缓存
使用实例
<filter>
<filter-name>CacheFilterStaticContent</filter-name>
<filter-class>com.opensymphony.oscache.web.filter.CacheFilter</filter-class>
<init-param>
<param-name>expires</param-name>
<param-value>time</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>CacheFilterStaticContent</filter-name>
<url-pattern>*.jsp</url-pattern>
</filter-mapping>
分享到:
相关推荐
ASP.NET缓存技术是提升Web应用性能的关键策略之一,它主要分为页面输出缓存和应用程序缓存两大类。这两种缓存机制旨在减少服务器处理请求的时间,降低数据库负载,并且提高用户体验,通过存储已经生成的HTML页面或...
在IT领域,尤其是在Web开发中,缓存技术是提高应用程序性能的关键策略之一。"缓存应用程序页面和数据"这一主题涵盖了如何有效地存储和检索经常访问的信息,以减少对数据库或其他昂贵资源的请求,从而降低延迟并提升...
同时,应用程序配置和缓存是两个核心概念,它们对优化性能和管理应用设置起着关键作用。 **ASP.NET内置对象** 1. **HttpContext**: 这是ASP.NET中最重要的对象之一,它包含了关于当前HTTP请求的所有信息,如请求...
在Android系统中,获取应用程序的大小、数据大小以及缓存数据是开发者或用户进行性能优化、存储管理的重要操作。下面将详细介绍如何实现这些功能,并解释相关知识点。 首先,我们需要了解Android应用的存储结构。每...
标题中的“灵活的工具通过纯JavaScript来处理客户端应用程序缓存”指的是使用JavaScript在浏览器环境中管理应用程序的缓存机制。这通常涉及到Web应用的性能优化,特别是对于离线存储或者需要减少网络请求的情况。...
本示例程序主要探讨了如何构建一个WCF缓存通道,以优化在Azure上运行的应用程序。 【描述】: 在WCF服务中,缓存通道是一种自定义行为,它能够在服务调用之间存储和重用数据,从而避免不必要的计算和网络通信。...
Android应用缓存机制是优化应用程序性能的关键组成部分,它涉及到如何高效地存储和检索数据,以减少网络请求和I/O操作,提升用户体验。Android系统提供了多种缓存策略和技术,包括内存缓存、磁盘缓存、SQLite数据库...
在C++编程中,应用程序性能优化是一个至关重要的领域,它涉及到如何提高代码的运行效率,减少资源消耗,以及提升整体的用户体验。以下是一些从标题和描述中推断出的关键知识点,以及从压缩包文件名可能涉及的内容: ...
### J2ME应用程序性能优化的探讨 #### 引言 随着移动互联网的快速发展,Java 2 Micro Edition(简称J2ME)作为一种适用于嵌入式设备和消费性电子产品上的Java平台,为开发者提供了丰富的开发工具和环境。然而,...
在Asp.NET应用程序中,性能优化是至关重要的,特别是对于高流量的网站。局部缓存是一种有效的优化策略,它可以显著减少服务器的负载,提高用户体验。本文主要探讨了局部缓存的几种解决方案,以及如何在Asp.NET中实现...
这包括优化应用程序的代码、数据库、网络请求、内存管理、图形渲染、缓存机制等方面,以提高应用程序的性能和用户体验。 Android 应用性能优化的重要性在于以下几个方面: 首先,性能优化可以提高应用程序的响应...
总的来说,掌握Android中的文件管理和缓存清理对于优化应用性能和用户体验至关重要。理解如何获取、计算和清除缓存,有助于开发者创建更加高效且用户友好的应用程序。同时,持续关注如“SD卡文件管理更新信息”这样...
例如,文件系统缓存减少磁盘I/O操作,数据库缓存减少对文件系统的依赖,应用程序缓存减少对数据库的查询,Web服务器缓存减轻应用服务器负担,而客户端浏览器缓存则减少了对网站内容的重复下载。 操作系统级别的缓存...
Android应用程序磁盘缓存则是Android系统为了提高应用性能和用户体验而引入的一种机制,它将经常使用的数据存储在设备的本地磁盘上,下次应用需要时可以直接从缓存读取,避免了网络延迟或IO操作的开销。 Android...
在微信小程序的开发中,数据缓存机制是一个重要的功能,它允许开发者将数据存储在用户的本地,以便在后续的页面加载或应用使用中快速访问,提高用户体验。本篇文章主要探讨了如何实现小程序的数据缓存机制,并通过...
全局程序集缓存的默认位置在操作系统的Windows目录下,路径为`C:\WINDOWS\assembly`,在这里,系统和应用程序可以找到并加载已经注册的共享程序集。 总的来说,程序集是.NET框架中构建和管理软件的关键组件,它实现...
1. 内存缓存:内存缓存是一种高效的缓存方式,它将图片存储在应用程序的内存中。当需要显示图片时,首先检查内存缓存中是否存在该图片,如果存在则直接从内存中读取,否则再从其他地方(如磁盘或网络)加载。但是,...
HTML5的应用程序缓存(Application Cache)是一种离线存储技术,旨在提高网页应用程序的性能和可用性,尤其在网络环境不稳定或无网络连接的情况下。在HTML5之前,网页需要持续在线才能正常工作,但Application Cache...
在ASP.NET应用程序优化领域,开发者们常常面临性能瓶颈、加载速度慢、资源消耗大等问题。本文将深入探讨如何从页面优化、程序优化以及数据库SQL优化三个方面来提升ASP.NET应用的性能,以达到最佳运行效果。 一、...