`

ehcache-web缓存的使用和清除

    博客分类:
  • java
 
阅读更多
引入jar包
<!--ehcache缓存-->
            <dependency>
                <groupId>net.sf.ehcache</groupId>
                <artifactId>ehcache-web</artifactId>
                <version>2.0.4</version>
            </dependency>


配置ehcache.xml
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:noNamespaceSchemaLocation="./ehcache.xsd" updateCheck="true" monitoring="autodetect" dynamicConfig="true">

    <!--自创建的时候起,缓存300秒,300秒后重新查询放入缓存-->
    <cache name="SimplePageCachingFilter"
           maxElementsInMemory="10000"
           eternal="false"
           overflowToDisk="false"
           timeToIdleSeconds="0"
           timeToLiveSeconds="300"
           memoryStoreEvictionPolicy="LFU" />

</ehcache>


配置web.xml
 <!--缓存设置-->
        <filter>
        <filter-name>SimplePageCachingFilter</filter-name>
        <filter-class>com.gome.home.controller.common.CacheFilter</filter-class>
        <init-param>
 <!--缓存线程锁超时间,默认无限期,导致程序永不响应-->
            <param-name>blockingTimeoutMillis</param-name>
            <param-value>500</param-value>
        </init-param>
        <init-param>
 <!--设置的缓存名称 默认为SimplePageCachingFilter-->
            <param-name>cacheName</param-name>
            <param-value>SimplePageCachingFilter</param-value>
        </init-param>

    </filter>

    <!--测试URL-->
    <filter-mapping>
        <filter-name>SimplePageCachingFilter</filter-name>
        <url-pattern>/test</url-pattern>
    </filter-mapping>



当访问/test这个URL的时候,ehcache会把生成的HTML全部放入缓存,再次访问时,从缓存中取出HTML直接输出,响应时间为20毫秒内,不需要缓存时,比如后台修改了部分数据,使用以下方式清空缓存,重新加载.

缓存的位置,默认是内存,速度最快,也可以配置为磁盘文件,如果文件较多,可以配置为磁盘文件,这种方式其实就是页面静态化的工作.而几乎不需作任何开发就实现了

清除缓存


import net.sf.ehcache.CacheManager;
import net.sf.ehcache.Ehcache;
import net.sf.ehcache.Element;
import net.sf.ehcache.constructs.web.PageInfo;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

import java.io.UnsupportedEncodingException;
import java.util.List;

@Controller()
@RequestMapping("/common/cache")
public class CacheController {
    public static final Logger logger  = LoggerFactory.getLogger(CacheController.class);
    public static final String DEFAULT_CACHE_NAME = "SimplePageCachingFilter";

    private static final CacheManager cacheManager = CacheManager.getInstance();

    @RequestMapping("clean")
    public @ResponseBody Boolean clean(){
        logger.debug("cache clean");
        String[] names = cacheManager.getCacheNames();
        logger.debug("cache names {}",names);
        BlockingCache cache = (BlockingCache)cacheManager.getEhcache(DEFAULT_CACHE_NAME);

        logger.debug("cache.getMemoryStoreSize() {}",cache.getMemoryStoreSize());
        List keys = cache.getKeys();
//for里的Element e = cache.get(k);必须注掉
          for(Object k:keys){
            logger.debug("clean cache key {}", k);

            //BlockingCache 取不到值将加上读写锁的写锁
            //等待写入数据 不写入数据将会死锁 此段代码必须注掉
            Element e = cache.get(k);
            if(e==null)continue;
            PageInfo pageInfo = (PageInfo)e.getObjectValue();
            try {
                if(pageInfo.hasGzippedBody()){
                    logger.debug("pageInfo.getGzippedBody() {}", new String(pageInfo.getUngzippedBody()));
                }
            } catch (Exception e1) {
                e1.printStackTrace();
            }
            //手动释放写锁无效 
            //cache.releaseWriteLockOnKey(k);
        }
        cache.removeAll();

        logger.debug("clean over ");
        return true;
    }
}


默认情况下,SimplePageCachingFilter会对输出的内容进行gzip压缩,这样的结果会导致
nginx SSI失效,解决此问题,可以使用自定义的filter,重新其中的writeContent方法
所有内容全不进行gzip输出即可

import net.sf.ehcache.constructs.web.PageInfo;
import net.sf.ehcache.constructs.web.ResponseHeadersNotModifiableException;
import net.sf.ehcache.constructs.web.ResponseUtil;
import net.sf.ehcache.constructs.web.filter.SimplePageCachingFilter;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.BufferedOutputStream;
import java.io.IOException;
import java.io.OutputStream;

/**
 * Created on 2016/3/15.
 */
public class CacheFilter extends SimplePageCachingFilter {
    public static final Logger logger  = LoggerFactory.getLogger(CacheController.class);

    @Override
    protected void writeContent(final HttpServletRequest request,
                                final HttpServletResponse response, final PageInfo pageInfo)
            throws IOException, ResponseHeadersNotModifiableException {

        logger.debug("customer filter working");

        byte[] body;

        boolean shouldBodyBeZero = ResponseUtil.shouldBodyBeZero(request,
                pageInfo.getStatusCode());
        if (shouldBodyBeZero) {
            body = new byte[0];
        } else {
            body = pageInfo.getUngzippedBody();
        }

        response.setContentLength(body.length);
        OutputStream out = new BufferedOutputStream(response.getOutputStream());
        out.write(body);
        out.flush();
    }
}
分享到:
评论

相关推荐

    ehcache-2.8.0-distribution.tar.gz

    Ehcache是一个开源的、高性能的Java缓存解决方案,它为应用程序提供了本地内存缓存的能力,从而提高了数据访问的速度和效率。在Ehcache 2.8.0版本中,这个分布式缓存系统引入了许多关键特性,使得它成为了Java开发者...

    ehcache-standalone-server-1.0.0-distribution.tar.gz 01

    9. 监控与管理:Ehcache Standalone Server提供了一个Web管理界面,允许管理员监控缓存性能、查看统计信息、调整配置,甚至进行操作如清除缓存等。 10. 性能调优:通过调整Ehcache的配置,比如增加缓存分区数量、...

    EhCache-Cluster-Tester.zip_cluster_cluster html网页_ehcache_java

    EhCache是一款高性能、轻量级的Java缓存框架,广泛应用于提高应用程序的性能和减少数据库负载。在“EhCache-Cluster-Tester.zip”这个压缩包中,包含了一个关于EhCache集群配置和测试的实例,这对于理解如何在分布式...

    ehcache jar包

    5. **缓存策略**:`ehcache`支持多种缓存策略,如LRU(Least Recently Used,最近最少使用)、LFU(Least Frequently Used,最不经常使用)和FIFO(First In First Out,先进先出)等,用于决定何时清除缓存中的数据...

    springMVC+Ehcache的各级缓存(包括页面缓存)

    SpringMVC和Ehcache的结合使用,能够构建一个高效、灵活的多级缓存系统,其中包括页面缓存。下面将详细介绍SpringMVC与Ehcache集成后的各级缓存机制以及页面缓存的实现。 1. SpringMVC简介: SpringMVC是Spring框架...

    ehcache-1.6.0-beta5-distribution.tar.gz

    Ehcache是一个开源的、广泛使用的Java分布式缓存系统,主要设计用于提高应用程序的性能和响应速度,通过存储经常访问的数据来减少对数据库的访问。Ehcache 1.6.0-beta5是该系统的一个早期版本,包含了若干重要的功能...

    Ehcache页面缓存的使用.doc

    总结起来,Ehcache页面缓存的使用涉及合理配置缓存的生命周期、大小限制以及淘汰策略,通过过滤器实现对请求的拦截和缓存内容的提供,以实现高效、低延迟的页面服务。在设计缓存策略时,要考虑到不同页面的访问特性...

    Ehcache整合Spring使用页面、对象缓存

    五、缓存清除与更新 Spring提供了`@CacheEvict`注解用于清除特定缓存。当某些操作导致缓存数据不再有效时,可以在方法上添加此注解。 ```java @Service public class UserService { @CacheEvict(value = ...

    spring使用ehcache实现页面缓存示例

    【Spring 使用 Ehcache 实现页面缓存】 在高并发的 Web 应用中,为了提高用户体验和减轻服务器压力,页面缓存是一种常见的优化手段。Spring 框架结合 Ehcache 提供了对页面缓存的支持,能够有效地加速静态或半静态...

    ehcache+spring demo 整合

    Ehcache 是一款高效、流行的Java缓存库,它能够帮助...这个项目是学习和理解如何在Spring应用中集成Ehcache的一个好起点,你可以通过运行这两个工程,观察缓存的使用效果,逐步掌握如何在实际项目中利用缓存优化性能。

    ehcache缓存页面

    Ehcache是一款广泛使用的Java缓存库,它能够有效提升应用程序性能,尤其是在处理高访问量的页面时。本文主要探讨如何利用Ehcache实现页面缓存,以及相关的配置和策略。 首先,理解Ehcache的两个关键参数: 1. `...

    Spring基于注解的缓存配置--web应用实例

    在Spring配置文件中,我们需要启用缓存管理和指定使用的缓存管理器。例如,如果我们使用Ehcache,我们需要配置EhcacheManager,并声明缓存的bean。 7. **Web应用集成** 在Web应用程序中,缓存通常需要考虑到并发...

    开源缓存包 EHCache 全接触

    EHCache 是一个广泛使用的开源 Java 缓存解决方案,它被设计用于提高应用程序的性能和响应速度,通过存储数据到内存中,避免了频繁的数据库访问。EHCache 适用于多种场景,包括 Web 应用、企业级服务和大数据处理等...

    ehcache三个小demo

    Ehcache是一款高效、流行的Java缓存框架,广泛...通过这三个小demo,你可以深入理解Ehcache的使用场景、配置方式和工作原理,无论是后台缓存还是前端缓存,都可以灵活地应用到实际项目中,提升系统的效率和响应速度。

    springMVC+Ehcache+MySQL

    这个项目中,通过Spring MVC、Ehcache和MySQL的结合,可以创建一个高性能的Web应用,其中Ehcache负责缓存热数据,减轻数据库压力,Spring MVC负责业务逻辑和视图渲染,MySQL则作为持久化存储,保证数据的安全性。...

    Ehcache使用手册

    本手册将详细讲解Ehcache的API使用、页面缓存和分布式缓存的配置。 1. **Ehcache API的使用** - **创建CacheManager**: Ehcache的核心管理组件是CacheManager,它负责创建、管理和销毁Cache实例。你可以使用`...

    spring整合ehcache的完整用例

    Ehcache是一个广泛使用的开源Java分布式缓存,它支持内存和磁盘存储,具有缓存热备、缓存复制等功能。下面将详细介绍Spring与Ehcache的整合过程及其相关知识点。 1. **Spring配置Ehcache** 在Spring应用中整合...

    springmvc+ehcache 实例

    在IT行业中,Spring MVC是一个广泛使用...通过这个实例,你可以深入理解Spring MVC和Ehcache的集成,并了解到缓存在提高Web应用性能上的重要作用。同时,这也是一个很好的实战练习,帮助你提升在实际项目中的开发能力。

    spring boot 使用jsp 集成hibernate+shiro+ehcache项目分享

    在这个项目中,我们将深入探讨如何将 Spring Boot 与 Hibernate、Shiro 和 Ehcache 结合,以实现一个高效且安全的 Web 应用。 **1. Spring Boot 与 Hibernate 集成** Hibernate 是一个强大的对象关系映射(ORM)...

    java shiro实现退出登陆清空缓存

    这里没有给出具体的缓存清理代码,因为实际应用中可能涉及不同的缓存实现(如 Redis、Memcached 或 Ehcache),清理缓存的方法会因缓存技术而异。 总之,通过扩展 Shiro 的 `LogoutFilter`,我们可以在用户登出时...

Global site tag (gtag.js) - Google Analytics