文档章节

ENHCASH分布式缓存

罗文浩
 罗文浩
发布于 2015/07/22 22:14
字数 1208
阅读 11
收藏 0
1. EHCache 的特点,是一个纯Java ,过程中(也可以理解成插入式)缓存实现,单独安装Ehcache ,需把ehcache-X.X.jar 和相关类库方到classpath中。如项目已安装了Hibernate ,则不需要做什么。。直接可以使用Ehcache 

Cache 存储方式 :内存或磁盘 

2. 单独使用 EHCache 

使用CacheManager 创建并管理Cache 
1.创建CacheManager有4种方式: 
A:使用默认配置文件创建  
Java代码  复制代码  收藏代码
  1. CacheManager manager = CacheManager.create();
CacheManager manager = CacheManager.create();

B:使用指定配置文件创建 
Java代码  复制代码  收藏代码
  1. CacheManager manager = CacheManager.create("src/config/ehcache.xml");
CacheManager manager = CacheManager.create("src/config/ehcache.xml");

C:从classpath中找寻配置文件并创建 
Java代码  复制代码  收藏代码
  1. URL url = getClass().getResource("/anothername.xml");
  2. CacheManager manager = CacheManager.create(url);
URL url = getClass().getResource("/anothername.xml");
CacheManager manager = CacheManager.create(url);

D:通过输入流创建  
Java代码  复制代码  收藏代码
  1. InputStream fis = new FileInputStream(new File("src/config/ehcache.xml").getAbsolutePath());
  2. try {
  3. manager = CacheManager.create(fis);
  4. finally {
  5. fis.close();
  6. }
InputStream fis = new FileInputStream(new File("src/config/ehcache.xml").getAbsolutePath());
try {
manager = CacheManager.create(fis);
} finally {
fis.close();
}


卸载CacheManager ,关闭Cache 

Java代码  复制代码  收藏代码
  1. manager.shutdown();
manager.shutdown();


使用Caches 

取得配置文件中预先 定义的sampleCache1设置,通过CacheManager生成一个Cache 

Java代码  复制代码  收藏代码
  1. Cache cache = manager.getCache("sampleCache1");
Cache cache = manager.getCache("sampleCache1");



设置一个名为test 的新cache,test属性为默认 

Java代码  复制代码  收藏代码
  1. CacheManager manager = CacheManager.create();
  2. manager.addCache("test");
CacheManager manager = CacheManager.create();
manager.addCache("test");


设置一个名为test 的新cache,并定义其属性 
Java代码  复制代码  收藏代码
  1. CacheManager manager = CacheManager.create();
  2. Cache cache = new Cache("test"1truefalse52);
  3. manager.addCache(cache);
CacheManager manager = CacheManager.create();
Cache cache = new Cache("test", 1, true, false, 5, 2);
manager.addCache(cache);



往cache中加入元素 
Java代码  复制代码  收藏代码
  1. Element element = new Element("key1""value1");
  2. cache.put(new Element(element);
Element element = new Element("key1", "value1");
cache.put(new Element(element);



从cache中取得元素 
Java代码  复制代码  收藏代码
  1. Element element = cache.get("key1");
Element element = cache.get("key1");


所以大概步骤为:
第一步:生成CacheManager对象
第二步:生成Cache对象
第三步:向Cache对象里添加由key,value组成的键值对的Element元素
 

具体一个Test.java程序: 
Java代码  复制代码  收藏代码
  1. package test;
  2. import net.sf.ehcache.Cache;
  3. import net.sf.ehcache.CacheManager;
  4. import net.sf.ehcache.Element;
  5. /**
  6. * 第一步:生成CacheManager对象
  7. * 第二步:生成Cache对象
  8. * 第三步:向Cache对象里添加由key,value组成的键值对的Element元素
  9. * @author mahaibo
  10. *
  11. */
  12. public class Test {
  13. public static void main(String[] args) {
  14. //指定ehcache.xml的位置
  15. String fileName="E:\\1008\\workspace\\ehcachetest\\ehcache.xml";
  16. CacheManager manager = new CacheManager(fileName);
  17. //取出所有的cacheName
  18. String names[] = manager.getCacheNames();
  19. for(int i=;i<names.length;i++){
  20. System.out.println(names[i]);
  21. }
  22. //根据cacheName生成一个Cache对象
  23. //第一种方式:
  24. Cache cache=manager.getCache(names[]);
  25. //第二种方式,ehcache里必须有defaultCache存在,"test"可以换成任何值
  26. // Cache cache = new Cache("test", 1, true, false, 5, 2);
  27. // manager.addCache(cache);
  28. //向Cache对象里添加Element元素,Element元素有key,value键值对组成
  29. cache.put(new Element("key1","values1"));
  30. Element element = cache.get("key1");
  31. System.out.println(element.getValue());
  32. Object obj = element.getObjectValue();
  33. System.out.println((String)obj);
  34. manager.shutdown();
  35. }
  36. }
package test;

import net.sf.ehcache.Cache;
import net.sf.ehcache.CacheManager;
import net.sf.ehcache.Element;
/**
 * 第一步:生成CacheManager对象
 * 第二步:生成Cache对象
 * 第三步:向Cache对象里添加由key,value组成的键值对的Element元素
 * @author mahaibo
 *

 */
public class Test {
	
	public static void main(String[] args) {
		  //指定ehcache.xml的位置
		  String fileName="E:\\1008\\workspace\\ehcachetest\\ehcache.xml";
		  CacheManager manager = new CacheManager(fileName);
		  //取出所有的cacheName
		  String names[] = manager.getCacheNames();
		  for(int i=0;i<names.length;i++){
			  System.out.println(names[i]);
		  }
		  //根据cacheName生成一个Cache对象
		  //第一种方式:
		  Cache cache=manager.getCache(names[0]);
		  
		  //第二种方式,ehcache里必须有defaultCache存在,"test"可以换成任何值
//		  Cache cache = new Cache("test", 1, true, false, 5, 2);   
//		  manager.addCache(cache); 
		  
		  //向Cache对象里添加Element元素,Element元素有key,value键值对组成
		  cache.put(new Element("key1","values1"));
		  Element element = cache.get("key1");
		  
		  System.out.println(element.getValue());
		  Object obj = element.getObjectValue();
		  System.out.println((String)obj);
		  manager.shutdown();
		  

	 }


}


3. 在 Hibernate 中运用EHCache 

hibernate.cfg.xml中需设置如下: 
2.1版本加入 
Java代码  复制代码  收藏代码
  1. <property name="hibernate.cache.provider_class">net.sf.ehcache.hibernate.Provider</property>
<property name="hibernate.cache.provider_class">net.sf.ehcache.hibernate.Provider</property>

2.1以下版本加入 
Java代码  复制代码  收藏代码
  1. <property name="hibernate.cache.provider_class">net.sf.hibernate.cache.EhCache</property>
<property name="hibernate.cache.provider_class">net.sf.hibernate.cache.EhCache</property>


在 Hibernate 映射文件的每个需要Cache的Domain中 
Java代码  复制代码  收藏代码
  1. <hibernate-mapping>
  2. <class
  3. name="com.somecompany.someproject.domain.Country"
  4. table="ut_Countries"
  5. dynamic-update="false"
  6. dynamic-insert="false"
  7. >
  8. ...
  9. </hibernate-mapping>
<hibernate-mapping>
<class
name="com.somecompany.someproject.domain.Country"
table="ut_Countries"
dynamic-update="false"
dynamic-insert="false"
> 
...

</hibernate-mapping>

加入类似如下格式信息: 
Java代码  复制代码  收藏代码
  1. <cache usage="read-write|nonstrict-read-write|read-only" />
<cache usage="read-write|nonstrict-read-write|read-only" />

比如: 
Java代码  复制代码  收藏代码
  1. <cache usage="read-write" />
<cache usage="read-write" />


具体如下: 

Java代码  复制代码  收藏代码
  1. <?xml version="1.0"?>
  2. <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
  3. "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
  4. <hibernate-mapping package="org.springside.bookstore.plugins.security.domain">
  5. <class name="User" table="SS_USERS" dynamic-insert="true" dynamic-update="true">
  6. <cache usage="nonstrict-read-write"/>
  7. <id name="id" column="ID">
  8. <generator class="native"/>
  9. </id>
  10. <property name="loginid" column="LOGINID" not-null="true"/>
  11. <property name="passwd" column="PASSWD" not-null="true"/>
  12. <property name="name" column="NAME" not-null="true"/>
  13. <property name="email" column="EMAIL"/>
  14. <property name="region" column="REGION"/>
  15. <property name="status" column="STATUS"/>
  16. <property name="descn" column="DESCN"/>
  17. <set name="roles" table="SS_USER_ROLE" lazy="true" inverse="false" cascade="save-update" batch-size="5">
  18. <key>
  19. <column name="USER_ID" not-null="true"/>
  20. </key>
  21. <many-to-many class="Role" column="ROLE_ID"/>
  22. </set>
  23. </class>
  24. </hibernate-mapping>
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="org.springside.bookstore.plugins.security.domain">
    <class name="User" table="SS_USERS" dynamic-insert="true" dynamic-update="true">
        <cache usage="nonstrict-read-write"/>
        <id name="id" column="ID">
            <generator class="native"/>
        </id>
        <property name="loginid" column="LOGINID" not-null="true"/>
        <property name="passwd" column="PASSWD" not-null="true"/>
        <property name="name" column="NAME" not-null="true"/>
        <property name="email" column="EMAIL"/>
        <property name="region" column="REGION"/>
        <property name="status" column="STATUS"/>
        <property name="descn" column="DESCN"/>
        <set name="roles" table="SS_USER_ROLE" lazy="true" inverse="false" cascade="save-update" batch-size="5">
            <key>
                <column name="USER_ID" not-null="true"/>
            </key>
            <many-to-many class="Role" column="ROLE_ID"/>
        </set>
    </class>
</hibernate-mapping>


然后在ehcache.xml中加入 
Java代码  复制代码  收藏代码
  1. <ehcache>
  2. <cache name="com.somecompany.someproject.domain.Country"
  3. maxElementsInMemory="10000"
  4. eternal="false"
  5. timeToIdleSeconds="300"
  6. timeToLiveSeconds="600"
  7. overflowToDisk="false"
  8. />
  9. </ehcache>

© 著作权归作者所有

共有 人打赏支持
罗文浩
粉丝 21
博文 138
码字总数 223451
作品 0
海淀
架构师
私信 提问
缓存技术在华为公有云环境中的挑战与应用

12月1日,ACMUG & CRUG 2018 技术沙龙全国巡演第十站在西安举办。华为云中间件产品经理 Kevin 在会上带来了《缓存技术在华为公有云环境中的挑战与应用》主题演讲,为大家介绍和分享了华为云分...

中间件小哥
2018/12/07
0
0
.NET 分布式缓存中间件--XXF.BaseService.DistributedCache

分布式缓存中间件 方便实现缓存的分布式,集群,负载均衡,故障自动转移,并兼容多种缓存存储的分布式缓存中间件。 用于解决分布式架构中的分布式缓存环节。 特点: 代码少,便于扩展。 兼容...

车江毅
2015/12/31
848
1
关于游戏服务器中缓存的设计方案的讨论

(只针对游戏服务器中的热数据)游戏服务器的缓存设计总体大概有三种类型:进程内缓存--如java的ehcahe、 进程内缓存--使用会话session Cache,通过语言的基础类型和基础的集合框架来定制 、...

石头哥哥
2014/10/31
0
0
[.NET领域驱动设计实战系列]专题八:DDD案例:网上书店分布式消息队列和分布式缓存的实现

原文:[.NET领域驱动设计实战系列]专题八:DDD案例:网上书店分布式消息队列和分布式缓存的实现 一、引言   在上一专题中,商家发货和用户确认收货功能引入了消息队列来实现的,引入消息队列...

杰克.陈
2017/12/05
0
0
Asp.Net Core 轻松学-正确使用分布式缓存

前言     本来昨天应该更新的,但是由于各种原因,抱歉,让追这个系列的朋友久等了。上一篇文章 在.Net Core 使用缓存和配置依赖策略 讲的是如何使用本地缓存,那么本篇文章就来了解一下...

Ron.liang
2018/12/24
0
0

没有更多内容

加载失败,请刷新页面

加载更多

使用Maven打包Docker镜像-Jenkins版

前提:Jenkins服务器上安装好Docker,创建Jenkins任务,配置好代码来源,和Build配置: pom.xml中添加docker-maven-plugin: <plugin> <groupId>com.spotify</groupId> <artifactI......

莫在全
17分钟前
0
0
rabbitmq

灰暗
58分钟前
1
0
Flink

flink HA部署 flink搭建,采用分布式部署方式,分别为A,B,C三个节点。其中A为master;A,B,C为worker。 本文使用的用户是hadoop用户(自己新建) 先决条件 Java 1.8.x or higher scala 自己使用...

-九天-
今天
2
0
数据中台和传统数仓的区别

中台系统把业务层同性的算法能力,服务能力,业务能力高度集成,有效组织 ,动态规划。更好的帮助上层业务。 今天就让我们看看关于数据中台的问答吧。 1 Q : 什么是数据中台? A : 数据中台是...

hblt-j
今天
5
0
Java在什么时候会出现内存泄漏

在Java中,内存泄漏就是存在一些被分配的对象,这些对象有下面两个特点,首先,这些对象是可达的,即在有向图中,存在通路可以与其相连;其次,这些对象是无用的,即程序以后不会再使用这些对...

群星纪元
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部