文档章节

缓存与饼干,spring mvc使用ehcache

duoduo3_69
 duoduo3_69
发布于 2013/11/04 11:27
字数 1284
阅读 1.2W
收藏 42

3 月,跳不动了?>>>

缓存与饼干,spring mvc使用ehcache

需要用到的jar包

ehcache-2.7.5.jar(主程序)
ehcache-spring-annotations-1.2.0.jar(注解)
guava-r09.jar(依赖)
slf4j-api-1.6.6.jar(依赖)

配置文件

####spring配置中需要添加如下内容 头部

xmlns:cache="http://www.springframework.org/schema/cache"
xsi:schemaLocation
http://www.springframework.org/schema/cache  
http://www.springframework.org/schema/cache/spring-cache-3.2.xsd  

<!-- 缓存配置 -->
<!-- 启用缓存注解功能(请将其配置在Spring主配置文件中) -->
<cache:annotation-driven cache-manager="cacheManager" />

<!-- Spring自己的基于java.util.concurrent.ConcurrentHashMap实现的缓存管理器(该功能是从Spring3.1开始提供的) -->
<!-- <bean id="cacheManager" class="org.springframework.cache.support.SimpleCacheManager"> 
	<property name="caches"> <set> <bean name="myCache" class="org.springframework.cache.concurrent.ConcurrentMapCacheFactoryBean"/> 
	</set> </property> </bean> -->

<!-- 若只想使用Spring自身提供的缓存器,则注释掉下面的两个关于Ehcache配置的bean,并启用上面的SimpleCacheManager即可 -->
<!-- Spring提供的基于的Ehcache实现的缓存管理器 -->
<bean id="cacheManagerFactory"
	class="org.springframework.cache.ehcache.EhCacheManagerFactoryBean">
	<property name="configLocation" value="classpath:ehcache.xml" />
</bean>
<bean id="cacheManager" class="org.springframework.cache.ehcache.EhCacheCacheManager">
	<property name="cacheManager" ref="cacheManagerFactory" />
</bean>

####ehcache.xml

<ehcache>
<diskStore path="java.io.tmpdir"/>
<defaultCache
       maxElementsInMemory="1000"
       eternal="false"
       timeToIdleSeconds="120"
       timeToLiveSeconds="120"
       overflowToDisk="false"/>
<cache name="myCache"
       maxElementsOnDisk="20000"
       maxElementsInMemory="2000"
       eternal="false"
       overflowToDisk="true"
       diskPersistent="true"/>
<cache name="cacheTest"
       maxElementsOnDisk="20000"
       maxElementsInMemory="2000"
       eternal="false"
       overflowToDisk="true"
       diskPersistent="true"/>
</ehcache>

示例代码

cache一般用在和数据库交互的地方service

示例

package com.service;

import java.util.Date;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;

import javax.annotation.Resource;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.cache.annotation.CacheEvict;
import org.springframework.cache.annotation.CachePut;
import org.springframework.cache.annotation.Cacheable;
import org.springframework.stereotype.Service;

import com.aft.site.yey.dao.NoticeDao;
import com.aft.site.yey.entity.Notice;
import com.app.jdbc.core.ToolUtil;

/**
 * @author: yangyang 2013年10月21日 
 * @since JDK 1.6
 */
@Service("XXXNoticeService")
public class NoticeService {
    private static Log logger = LogFactory.getLog(NoticeService.class);
    @Resource(name = "XXXNoticeDao")
    private NoticeDao dao;

    /**
     * status = 0 指未删除
     * */
    @Cacheable(value = "cacheTest",key="'noticelist'")
    public List<Notice> topN(int begin, int end) {
	    LinkedHashMap<String, String> orderby = new LinkedHashMap<String, String>();
	    orderby.put("publish_time", "desc");
	    Map<String, String> where = new HashMap<String, String>();
	    where.put(dao.STATUS + " = ? ", dao.NORMAL_CODE.toString());
        //TODO:delete
        System.out.println("list:");
	    logger.info("[list ]");
	    return dao.find(where, orderby, begin, end);
    }

    @CacheEvict(value = "cacheTest",key="'noticelist'")
    public void delete(String id) {
        //TODO:delete
        System.out.println("delete:");
	    logger.info("delete ");
	    dao.delete(id, false);
    }

    @CacheEvict(value = "cacheTest", allEntries = true)
    public void save(Notice notice) {
	    notice.setRowid(ToolUtil.getUUID());
	    notice.setStatus(dao.NORMAL_CODE);
	    notice.setPublish_time(new Date());
	    // TODO:yeyid的获得方式
	    notice.setYey_id("123");
	    dao.insert(notice);
        //TODO:delete
        System.out.println("save:");
	    logger.info("save ");
    }

    public Notice get(String id) {
	    return dao.findById(id);
    }

    //@CachePut(value = "cacheTest",key="#notice.getRowid()")
    public void update(Notice notice) {
	    Map<String, String> set = new HashMap<String, String>();
	    LinkedHashMap<String, String> where = new LinkedHashMap<String, String>();
	    set.put("title", notice.getTitle());
	    set.put("author", notice.getAuthor());
	    set.put("content", notice.getContent());
	    where.put(dao.getIdColumnName() + "=?", notice.getRowid());
	    dao.update(set, where);
        System.out.println("update:");
	    logger.info("update ");
    }

}

使用说明

cache主要注解使用:@Cacheable,@CacheEvict,@CachePut

缓存是这样的,取值时在方法(A)调用前查一下缓存中是否有目标值,缓存存在的话直接从缓存中拿出不再去执行方法(A),这也是最基本的*@Cacheable*的概念;

缓存中有值需要更新怎么办?使用@CacheEvict来更新,这个注解的意思是删除掉缓存里面的某个值,从而达到更新缓存的效果。关于缓存更新,例如,取topN个对象,第一次取的时候比如是前1~10个,缓存中存这1~10的一个集合对象,第二次取的时候直接从缓存中拿,这没问题,现在是这样的,假设数据库中删除了1~10个元素中的任意一个值,这样数据库中的topN与缓存中的topN就不同步了,下次你在前台取topN的时候,因为缓存里面有这个对象,根据之前的介绍(取值时在方法(A)调用前查一下缓存中是否有目标值,缓存存在的话直接从缓存中拿出不再去执行方法(A)),方法A被略过,查的值不是真正的topN了,因此需要在add或者delete之后删除掉原来的缓存,保持数据一致。其他情景请自行考虑。

根据缓存的特性,如何做到既要保证方法被调用,又希望结果被缓存呢?直接使用*@CachePut*,他与@Cacheable的区别就在与方法是会被执行的。

注解里面属性解释,@Cacheable 与@CachePut一样, @CacheEvict还有和删除有关的两个属性:

  1. value:缓存的名称,在spring配置文件中定义,必须指定至少一个

    • 例如:@Cacheable(value=”mycache”) 或者 @Cacheable(value={”cache1”,”cache2”}
  2. key:缓存的key,(缓存是键值对儿)可以为空,如果指定要按照 SpEL 表达式编写,如果不指定,则缺省按照方法的所有参数进行组合

    • 例如: @Cacheable(value=”testcache”,key=”#userName”)
    • 使用字符串"'sss'"
    • 调用对象getName方法key=”#userName.getName()”
  3. condition:缓存的条件,可以为空,使用SpEL 编写,返回 true 或者 false,只有为 true 才进行缓存

    • 例如: @Cacheable(value=”testcache”,condition=”#userName.length()>2”)
  4. allEntries:是否清空所有缓存内容,缺省为 false,如果指定为 true,则方法调用后将立即清空所有缓存

    • 例如: @CachEvict(value=”testcache”,allEntries=true)
  5. beforeInvocation:是否在方法执行前就清空,缺省为 false,如果指定为 true,则在**方法还没有执行的时候就清空缓存*,缺省情况下为false,这样如果方法执行抛出异常,则不会清空缓存

    • 例如: @CachEvict(value=”testcache”,beforeInvocation=true)

下一步

集群的同步问题,未完待续。

相关链接

###非常详细的spring mvc和cache的使用博客 http://www.ibm.com/developerworks/cn/opensource/os-cn-spring-cache/

###官网文档 http://docs.spring.io/spring/docs/3.1.0.M1/spring-framework-reference/html/cache.html

###ehcache介绍 http://my.oschina.net/coolfire368/blog/123377

###spring mvc整合 ehcache http://blog.csdn.net/jadyer/article/details/12257865

© 著作权归作者所有

duoduo3_69
粉丝 89
博文 57
码字总数 83746
作品 0
青岛
程序员
私信 提问
加载中

评论(5)

c
chunfeng0060
新版的还要加一个:<property name="shared" value="true"></property>
duoduo3_69
duoduo3_69 博主

引用来自“wangle85”的评论

转行Python了吗?28
对啊
胖子没烦恼
胖子没烦恼
转行Python了吗?28
duoduo3_69
duoduo3_69 博主

引用来自“电脑小童”的评论

"集群的同步问题,未完待续。"什么时候出啊?
sorry 暂时续不上了 笔者已经不做java好久了
电脑小童
电脑小童
"集群的同步问题,未完待续。"什么时候出啊?
Spring mvc 3.0 页面缓存

问: 基于Spring mvc 3.0 + Spring jdbc 注解开发项目(自己学联系哟),在考虑页面缓存时,google了资料,网速有介绍搭载 EhCache 的缓存开发,有搭载Hibernate的。 想问一下,大家在用Sprin...

zerohh
2013/04/02
1.5K
5
Spring Boot缓存实战 EhCache

Spring boot默认使用的是SimpleCacheConfiguration,即使用ConcurrentMapCacheManager来实现缓存。但是要切换到其他缓存实现也很简单 pom文件 在pom中引入相应的jar包 配置文件 EhCache所需要...

xiaolyuh
2019/09/23
35
0
oschina 为什么响应这么快?

红薯老大,您好!请问下oschina 是用了页面缓存还是页中的数据缓存。我有看过老大开源的ehcache的缓存代码,还有oschina的架构ppt,其中用的MVC框架是spring MVC吗?view 是用jsp 还是 velo...

uemc
2012/02/04
916
1
Spring思维导图,让Spring不再难懂(cache篇)

关于缓存 缓存是实际工作中非常常用的一种提高性能的方法。而在java中,所谓缓存,就是将程序或系统经常要调用的对象存在内存中,再次调用时可以快速从内存中获取对象,不必再去创建新的重复...

MarkerHub
2017/08/28
7.8K
10
springmvc的DispatcherServlet如何与ContextLoaderListener搭配配置?

我的工程一直在用springmvc,spring版本是3.0.7。我在web.xml里没有配置ContextLoaderListener,是直接通过DispatcherServlet来加载所有spring的xml文件。如此ioc和mvc url映射都是正常的。 ...

erdo
2013/11/16
8.4K
4

没有更多内容

加载失败,请刷新页面

加载更多

专业视频下载工具:Allavsoft for Mac

作为MacOS系统上的一款专业视频下载工具,Allavsoft mac破解版可以帮助用户快速进行视频在线下载和转换功能,Allavsoft中文版支持从雅虎、YouTube、Facebook等多达100家的视频分享网站的影片...

MacW软件分享
28分钟前
19
0
【德邦快递】从发货、分拨、分拣到配送,敏态数字化团队支撑高效的供应链!

“2019双11物流订单量创下新纪录,11月11号天猫全天物流订单突破10.42亿,截止至当天18:42,德邦快递宣布大件快递单产品实现收入破亿!” 如今物流行业强劲的运输效能,撑起了我们习以为常的...

嘉为科技
37分钟前
15
0
答应我,不会这些概念,简历不要写 “熟悉” zookeeper

唠唠叨叨 本文主要分享一下zookeeper的一些基本概念,在正式进入正题前,和大家聊一聊刚入行时我的面试经验,可以说是耿直的有些可爱。 面试官:用过zookeeper 吗? 我:用过啊,给dubbo提供...

程序员内点事
38分钟前
15
0
GitLab备份与恢复

因公司更换服务器服务商,服务器迁移到另外一家服务商,今天就模拟线上迁移gitlab的操作 git-A IP:192.168.82.184 git-B IP:192.168.82.184 在做备份迁移前提是版本号一样,否则会失败. Step ...

Linux_Anna
40分钟前
14
0
Snippetty for Mac(现场代码演示工具) v1.7.1

Snippetty是一个从markdown文件加载代码片段的应用程序。Snippetty Mac破解版适合每个人,Snippetty不会假设您的演示文稿的全部内容,只需要在正确的时间将正确的代码段放入计算机的剪贴板中...

麦克W
49分钟前
19
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部