`

j2ee页面静态化方案encache web cache框架详解1

 
阅读更多

web caching

 

1.介绍

Ehcache Web 是 EhCache 缓存框架的一个组件,主要用于Java开发Web项目中的一些缓存功能。包括一个单页缓存过滤器:SimplePageCachingFilter;页面压缩(gzip)支持;页面片段缓存等功能。在某些情况下能够很好的提高web应用的性能。

 

2.simplePageCachingFilter

   能够缓存httpresponse的html,json,xml等输出的完整页面或者页面片段的缓存,也支持gzipping的页面缓存。页面片段缓存可以参考SimplePageFragmentCachingFilter类。

 

3.keys 缓存的key值

   缓存的key是依赖的查询url和query查询参数串,比如/admin/SomePage.jsp?id=1234&name=Beagle。不依赖于url的域名和端口号,所以对于绑定多个域名的同一台机器也是有效地。但是如果url加了一些为了跟踪用户行为用的序列生成的id号,则无法使用缓存。在这种情况下你也可以重写calculateKey(javax.servlet.http.HttpServletRequest)这个方法来定义自己缓存的key。

 

4.多线程并发缓存失效问题

   为了避免多线程并发导致cache失效之类的问题,可以通过设置init-param的 blockingTimeoutMillis参数,指定第一个获得锁的线程的超时时间,避免后续请求阻塞。

 

5.gzipping

  浏览器如果支持Accept-Encoding: gzip,则在缓存中直接取出gzip的response结果,如果浏览器不支持,则cache会通过高效的ungzipped之后把结果输出到response上。

 

6.caching headers

  SimpleCachingHeadersPageCachingFilter 这个类能够缓存http请求 headers的ETag, Last-Modified 和Expires字段,支持get请求。这样是为了让浏览器快速获取某个页面是否浏览器缓存失效问题。

 

7.web。xml中可以设置的 init-params
  • cacheName -ehcache.xml 用户设置的filter的cache名称
  • blockingTimeoutMillis - the time, in milliseconds, to wait for the filter chain to return with a response on a cache miss. This is useful to fail fast in the event of an infrastructure failure.
  • varyHeader - set to true to set Vary:Accept-Encoding in the response when doing Gzip. This header is needed to support HTTP proxies however it is off by default.
 8.SimplePageFragmentCacheingFilter

 

跟simplePageCachingFilter差不多,不过不支持gzip,这样才能对多个页面进行合并。

 

9.web.xml的配置

   <web-app xmlns="http://java.sun.com/xml/ns/javaee"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
version="2.5">

 <filter>
<filter-name>CachePage1CachingFilter</filter-name>
<filter-class>net.sf.ehcache.constructs.web.filter.SimplePageCachingFilter
</filter-class>
<init-param>
 <param-name>suppressStackTrace</param-name>
 <param-value>false</param-value>
</init-param>
<init-param>
 <param-name>cacheName</param-name>
 <param-value>CachePage1CachingFilter</param-value>
</init-param>
 </filter>

 <filter>
<filter-name>SimplePageFragmentCachingFilter</filter-name>    <filter-class>net.sf.ehcache.constructs.web.filter.SimplePageFragmentCachingFilter
</filter-class>
<init-param>
 <param-name>suppressStackTrace</param-name>
 <param-value>false</param-value>
</init-param>
<init-param>
 <param-name>cacheName</param-name>
 <param-value>SimplePageFragmentCachingFilter</param-value>
</init-param>
 </filter>

 <filter>
<filter-name>SimpleCachingHeadersPageCachingFilter</filter-name>    <filter-class>net.sf.ehcache.constructs.web.filter.SimpleCachingHeadersPageCachingFilter
</filter-class>
<init-param>
 <param-name>suppressStackTrace</param-name>
 <param-value>false</param-value>
</init-param>
<init-param>
 <param-name>cacheName</param-name>
 <param-value>CachedPage2Cache</param-value>
</init-param>
 </filter>

 <!-- This is a filter chain. They are executed in the order below.
      Do not change the order. -->

 <filter-mapping>
<filter-name>CachePage1CachingFilter</filter-name>
<url-pattern>/CachedPage.jsp</url-pattern>
<dispatcher>REQUEST</dispatcher>
<dispatcher>INCLUDE</dispatcher>
<dispatcher>FORWARD</dispatcher>
 </filter-mapping>

 <filter-mapping>
<filter-name>SimplePageFragmentCachingFilter</filter-name>
<url-pattern>/include/Footer.jsp</url-pattern>
 </filter-mapping>

 <filter-mapping>
<filter-name>SimplePageFragmentCachingFilter</filter-name>
<url-pattern>/fragment/CachedFragment.jsp</url-pattern>
 </filter-mapping>

 <filter-mapping>
<filter-name>SimpleCachingHeadersPageCachingFilter</filter-name>
<url-pattern>/CachedPage2.jsp</url-pattern>
 </filter-mapping>
  10.ehcache.xml的配置

   <Ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:noNamespaceSchemaLocation="../../main/config/ehcache.xsd">
<diskStore path="java.io.tmpdir"/>
 <defaultCache
   maxEntriesLocalHeap="10"
   eternal="false"
   timeToIdleSeconds="5"
   timeToLiveSeconds="10"
   overflowToDisk="true"
   />
  <!-- Page and Page Fragment Caches -->
<cache name="CachePage1CachingFilter"
  maxEntriesLocalHeap="10"
  eternal="false"
  timeToIdleSeconds="10000"
  timeToLiveSeconds="10000"
  overflowToDisk="true">
</cache>
<cache name="CachedPage2Cache"
  maxEntriesLocalHeap="10"
  eternal="false"
  timeToLiveSeconds="3600"
  overflowToDisk="true">
</cache>
<cache name="SimplePageFragmentCachingFilter"
  maxEntriesLocalHeap="10"
  eternal="false"
  timeToIdleSeconds="10000"
  timeToLiveSeconds="10000"
  overflowToDisk="true">
</cache>
<cache name="SimpleCachingHeadersTimeoutPageCachingFilter"
  maxEntriesLocalHeap="10"
  eternal="false"
  timeToIdleSeconds="10000"
  timeToLiveSeconds="10000"
  overflowToDisk="true">
</cache>
</ehcache>

 

11.caching filter的异常

FilterNonReentrantException 当同一个线程再次重入caching filter处理时抛出异常,因为当第一个请求还未block时,同一个线程再次进入该filter就会block

ResponseHeadersNotModifiableException类似FilterNonReentrantException 

AlreadyGzippedException 如果已经对一个页面进行gzip处理,再次gzip时就抛出该异常

ResponseHeadersNotModifiableException如果对页面进行gzip处理,那么需要重新设置setheader的值,如果在设置过程中出错了,则抛出该异常。

 

参考:http://www.ehcache.org/documentation/user-guide/web-caching

 

对源码实现欢迎参考 http://zhwj184.iteye.com/blog/1545157

1
0
分享到:
评论

相关推荐

    encache缓存

    1. **配置**: 配置`EnCache`通常涉及设置缓存大小、过期策略、持久化选项等。 2. **API使用**: 通过Java API,我们可以创建、读取、更新和删除缓存中的数据。 3. **Spring整合**: `EnCache`与Spring框架有很好的集成...

    spring-cache.xsd+spring-encache.xsd

    标题中的"spring-cache.xsd+spring-encache.xsd"提到了两个XML Schema定义文件,它们是Spring框架中用于缓存管理的配置规范。Spring框架是一个广泛应用的Java企业级应用开发框架,它提供了多种功能,包括但不限于...

    encache 1 1 1 3 1 5 jar包

    总的来说,EnCache系列jar包为Java开发者提供了多样化的缓存解决方案。通过合理选择和使用encache-1.1.jar、encache-1.3.jar或encache-1.5.jar,开发者可以根据项目的具体需求,构建出高效、稳定、易维护的缓存系统...

    javaweb之encache缓存所需所有jar包

    EnCache是一个流行的选择,它为Java应用程序提供了高效、可扩展的缓存解决方案。本文将详细介绍EnCache缓存系统,以及与之相关的jar包需求。 EnCache是由Spring社区开发的一个分布式缓存系统,它支持在多个节点之间...

    ENCACHE缓存简介

    Ehcache,作为一款高效的Java开源缓存框架,它的广泛应用在于其灵活性和高效性。它不仅可以与Spring框架无缝集成,自Spring 3.1版本之后,通过注解配置即可便捷地使用,还能够与Hibernate ORM框架配合,成为其默认的...

    encache.jar

    **encache.web.jar** 则是针对Web应用程序的扩展,它提供了与Web应用服务器的集成,使得在Web环境中使用Ehcache更为方便。它可能包含对Servlet容器的适配器、过滤器、监听器等,以支持Web应用的缓存需求。 源码的...

    spring、 spring mvc、 hibernate、 ehcache JavaWeb后台框架

    在Spring框架中,Ehcache可以与Spring Cache模块集成,方便地在项目中启用缓存功能。 这四个框架的整合使用,能够构建出一套完整的JavaWeb后台解决方案。Spring作为基础框架,提供整体的管理和服务;Spring MVC处理...

    java中的Encache一个工具类

    使用Encache进行缓存存取的工具类,java中使用,配置好配置文件就可以使用

    看透 Spring MVC 源代码分析与实践 —— 网站基础知识.docx

    页面静态化技术可以使用模板技术来生成静态页面,例如 Velocity 和 FreeMaker 等。 4. 数据库优化 数据库优化是指对数据库的结构和 SQL 语句进行优化,以提高网站的性能和可扩展性。常见的数据库优化方法有: * ...

    encache+jgroups集群缓存共享

    总的来说,"encache+jgroups集群缓存共享"是一个深度整合分布式缓存和群组通信的技术方案,它结合了EnCache的高性能缓存特性与JGroups的稳定通信能力,为大型分布式系统提供了高效、可靠的缓存解决方案。理解和掌握...

    包含Redis,memcache,encache的NoSQL入门

    **EnCache** 主要是Java环境中的一种缓存框架,最初由Apache提供,后来被Adobe接手并开源。EnCache提供了缓存管理、事务处理、缓存分区等功能,支持多种缓存策略。它可以在应用程序服务器内部运行,减少了网络通信...

    ehcache缓存入门项目

    EhCache是一个开源的、高性能的Java缓存框架,它被广泛用于提高应用程序的性能,减少数据库负载。在这个“ehcache缓存入门项目”中,我们将深入探讨EhCache的基本概念、配置、使用方法以及一些实用技巧。 1. **...

    springMVC+Ehcache+MySQL

    Spring MVC 是一个强大的Java Web开发框架,用于构建高效、可维护的Web应用程序。它与Ehcache和MySQL的集成,可以极大地提升应用的性能和用户体验。在这个项目中,Ehcache作为缓存机制,用于存储频繁访问的数据,以...

    ehcache 例子

    **Ehcache 集群实例详解** Ehcache 是一款高效、易用且功能丰富的内存缓存系统,常用于Java应用中以提高数据访问性能。它支持分布式缓存,可以构建高性能的集群环境,有效地分发负载并提高系统的响应速度。在本篇...

    Spring 项目实战框架

    SpringWeb 架构(Maven+SpringMVC+SpringJDBC+Apache Shiro+Redis+MongoDB+EnCache+Freemarker+JSP)定位架构,借助Springside框架,好资源多分享

    Ehcache例子

    总结来说,Ehcache与Spring的结合提供了强大的缓存解决方案,可以显著提升Java应用的性能。通过注解驱动的缓存管理,开发者可以轻松地在代码中实现缓存策略,而无需深入底层细节。结合Spring的其他模块,如Web和ORM...

    看透 Spring MVC 源代码分析与实践 —— 网站基础知识.pdf

    标题 "看透 Spring MVC 源代码分析与实践" 提示我们主要关注的是Spring MVC这一Web开发框架的源代码分析和实际应用。Spring MVC是Spring框架的一个模块,它提供了处理HTTP请求、响应以及数据绑定等功能,是构建Web...

    J2Cache 使用Ceffien作为一级缓存,使用Redis作为二级缓存时的配置

    J2Cache是一个流行的Java缓存解决方案,它允许开发者将数据存储在内存中以减少对数据库的访问。在这个配置中,J2Cache结合了Caffeine作为一级缓存和Redis作为二级缓存,构建了一个高效的分布式缓存系统。 首先,让...

    Java流行ehcache缓存

    Ehcache 是一款广泛应用于Java开发中的开源缓存框架,其高效、易用且功能强大的特点使其在处理大量数据快速访问的问题上表现出色。本文将详细介绍Ehcache的基础知识、配置以及如何在实际项目中应用。 1. **Ehcache...

    Spring+EhCache缓存实例

    Spring框架与EhCache的结合,为开发者提供了一种高效、易用的缓存解决方案。本文将深入探讨Spring如何与EhCache协同工作,以及如何在实际项目中实施和配置。 **1. EhCache简介** EhCache是Java的一个开源、高性能...

Global site tag (gtag.js) - Google Analytics