`
zhyt710
  • 浏览: 205652 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

ehcache1.6使用(2)-- 集群

阅读更多

这篇我将探讨ehcache的集群配置,并写两个分布在不同逻辑机器上的程序去测试是不是达到了集群效果。我的目标就是得到踏踏实实的配置成功的感觉。

 

一.集群配置方式

ehcache提供三种网络连接策略来实现集群,rmi,jgroup还有jms。这里只说rmi方式。同时ehcache可以可以实现多播的方式实现集群。也可以手动指定集群主机序列实现集群,本例应用手动指定。

 

这里说点题外话,本来看着分发包中的原来的例子配置是一件不怎么难的事情,应该很容易就能实现。但是一开始,我是在我的linux主机上和我的主操作系统windows上实现集群配置。结果反过来弄过去,都没有成功。然后在网上找一些别人的配置经验,竟然都是配置片段,没有完整的实例文件。结果配置半天没成功。但我怀疑是我的linux系统有些地方可能没有配置好,于是先不管他。有开启了我的另一个windows主机。然后把程序部署上去,竟然一次试验成功。高兴的同时,我得发句话“不要把代码片段称作实例,这很不负责任”。同时还存在一个问题,在linux下没有部署成功的原因有待查明

 

具体说明:配置cacheManagerPeerListenerFactory是配宿主主机配置监听程序,来发现其他主机发来的同步请求

配置cacheManagerPeerProviderFactory是指定除自身之外的网络群体中其他提供同步的主机列表,用“|”分开不同的主机。

下面的例子的测试过程是:主机B缓存开启,并从名为UserCache的缓存中循环抓取键值为“key1”的元素,直到取到,才退出循环。主机A缓存启动,并在名为UserCache的缓存中放入键值为“key1”的元素。显然,如果主机B取到的元素,那么就证明同步成功,也就是集群成功。

所以在测试过程中先启动主机B的测试程序,在启动主机A的测试程序。

 

下面具体说配置文件以及测试程序:

1. 主机A的配置文件以及测试源代码

config/ehcache_cluster.xml

<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:noNamespaceSchemaLocation="ehcache.xsd">
	<cacheManagerPeerProviderFactory
		class="net.sf.ehcache.distribution.RMICacheManagerPeerProviderFactory"
		properties="peerDiscovery=manual, 
        rmiUrls=//192.168.1.254:40000/UserCache" />

	<cacheManagerPeerListenerFactory
		class="net.sf.ehcache.distribution.RMICacheManagerPeerListenerFactory"
		properties="hostName=192.168.1.126,port=40000,socketTimeoutMillis=120000" />

	<defaultCache maxElementsInMemory="10000" eternal="false"
		timeToIdleSeconds="120" timeToLiveSeconds="120" overflowToDisk="true"
		diskSpoolBufferSizeMB="30" maxElementsOnDisk="10000000"
		diskPersistent="false" diskExpiryThreadIntervalSeconds="120"
		memoryStoreEvictionPolicy="LRU">
		<cacheEventListenerFactory
			class="net.sf.ehcache.distribution.RMICacheReplicatorFactory" />
	</defaultCache>

	<cache name="UserCache" maxElementsInMemory="1000" eternal="false"
		timeToIdleSeconds="100000" timeToLiveSeconds="100000"
		overflowToDisk="false">
		<cacheEventListenerFactory
			class="net.sf.ehcache.distribution.RMICacheReplicatorFactory" />
	</cache>
</ehcache>

 tutorial/UsingCacheCluster

package tutorial;

import java.net.URL;

import net.sf.ehcache.Cache;
import net.sf.ehcache.CacheManager;
import net.sf.ehcache.Element;

public class UsingCacheCluster {

	public static void main(String[] args) throws Exception {
		URL url = UsingCacheCluster.class.getClassLoader().getResource(
				"config/ehcache_cluster.xml");
		CacheManager manager = new CacheManager(url);
		//取得Cache
		Cache cache = manager.getCache("UserCache");
		Element element = new Element("key1", "value1");
		cache.put(element);

		Element element1 = cache.get("key1");
		System.out.println(element1.getValue());
	}

}

2.  主机B上的配置文件以及测试代码

config/ehcache_cluster.xml

<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:noNamespaceSchemaLocation="ehcache.xsd">
	<cacheManagerPeerProviderFactory
		class="net.sf.ehcache.distribution.RMICacheManagerPeerProviderFactory"
		properties="peerDiscovery=manual, 
        rmiUrls=//192.168.1.126:40000/UserCache" />

	<cacheManagerPeerListenerFactory
		class="net.sf.ehcache.distribution.RMICacheManagerPeerListenerFactory"
		properties="hostName=192.168.1.254,port=40000, socketTimeoutMillis=120000" />

	<defaultCache maxElementsInMemory="10000" eternal="false"
		timeToIdleSeconds="120" timeToLiveSeconds="120" overflowToDisk="true"
		diskSpoolBufferSizeMB="30" maxElementsOnDisk="10000000"
		diskPersistent="false" diskExpiryThreadIntervalSeconds="120"
		memoryStoreEvictionPolicy="LRU">
		<cacheEventListenerFactory
			class="net.sf.ehcache.distribution.RMICacheReplicatorFactory" />
	</defaultCache>

	<cache name="UserCache" maxElementsInMemory="1000" eternal="false"
		timeToIdleSeconds="100000" timeToLiveSeconds="100000"
		overflowToDisk="false">
		<cacheEventListenerFactory
			class="net.sf.ehcache.distribution.RMICacheReplicatorFactory" />
	</cache>
</ehcache>

 

 

tutorial/UsingCacheCluster

package tutorial;

import java.net.URL;

import net.sf.ehcache.Cache;
import net.sf.ehcache.CacheManager;
import net.sf.ehcache.Element;

public class UsingCacheCluster {

	public static void main(String[] args) throws Exception {
		URL url = UsingCacheCluster.class.getClassLoader().getResource(
				"config/ehcache_cluster.xml");
		CacheManager manager = new CacheManager(url);
		//取得Cache
		Cache cache = manager.getCache("UserCache");

		while(true) {
			Element e = cache.get("key1");
			if(e != null) {
		        System.out.println(e.getValue());
			    break;
			}
			Thread.sleep(1000);
		}
	}

}
分享到:
评论
4 楼 chaisencs 2011-12-19  
请教楼主,automatic的peer discovery怎么配置,我参照了很多资料(官方文档等等)都不成功,防火墙什么的都关了,实验机器是一台ubuntu10.04,一台windows7,通过sniffer工具检查两台机器向多播地址“230.0.0.1”发送数据,但是没有收到回复,通过ehcache monitor的检测也发现二级缓存没有同步更新。多谢楼主了!
3 楼 轮回的猫 2009-06-05  
  楼主能发个 jms 实现ehcache集群的例子 或者说明吗?
2 楼 zhyt710 2009-05-06  
注意把 我文中提到的配置文件放在 “类路径”下。
khypiao 写道

你好!我用你给出的代码作了测试,但是总会出现如下问题: 2009-5-6 12:45:45 net.sf.ehcache.config.ConfigurationFactory parseConfiguration 警告: No configuration found. Configuring ehcache from ehcache-failsafe.xml&nbsp; found in the classpath: jar:file:/F:/ehcache-1.6.0-beta3/ehcache-1.6.0-beta3.jar!/ehcache-failsafe.xml Exception in thread "main" java.lang.NullPointerException at UsingCacheCluster.main(UsingCacheCluster.java:16) 能有什么建议吗?

注意把 我文中提到的配置文件放在 “类路径”下
1 楼 khypiao 2009-05-06  
你好!我用你给出的代码作了测试,但是总会出现如下问题:
2009-5-6 12:45:45 net.sf.ehcache.config.ConfigurationFactory parseConfiguration
警告: No configuration found. Configuring ehcache from ehcache-failsafe.xml  found in the classpath: jar:file:/F:/ehcache-1.6.0-beta3/ehcache-1.6.0-beta3.jar!/ehcache-failsafe.xml
Exception in thread "main" java.lang.NullPointerException
at UsingCacheCluster.main(UsingCacheCluster.java:16)


能有什么建议吗?

相关推荐

    ehcache-terracotta代码配置

    当与Terracotta结合使用时,Ehcache可以实现分布式缓存,使得多台服务器上的应用可以共享同一份缓存数据,从而构建高可用的集群环境。在本篇中,我们将深入探讨如何在Java项目中配置Ehcache与Terracotta来实现这一...

    ehcache配置使用详解

    2. **简单**:其简洁的API和丰富的文档使ehcache易于集成和使用,即使是对缓存技术不熟悉的开发者也能快速上手。 3. **多种缓存策略**:ehcache支持LRU(Least Recently Used)、LFU(Least Frequently Used)和FIFO...

    EhcacheUserGuide-1.6

    ### Ehcache 1.6 用户指南关键知识点解析 #### 一、引言 Ehcache 1.6 用户指南深入探讨了缓存技术的核心概念及其在现代应用中的重要作用。缓存,作为提升应用性能和可扩展性的关键策略,通过减少重复数据访问的...

    Ehcache缓存配置

    - 从 Ehcache 1.6 开始,支持 UTF-8 编码的 ehcache.xml 文件,但为了兼容旧版配置文件,ASCII 编码依然有效。 ##### 4.3 多个 CacheManager 使用同一配置文件 当多个 CacheManager 共享相同的配置文件时,可能会...

    采用apache实现tomcat的集群配置方案[文].pdf

    本文详细介绍了如何使用Apache作为负载均衡器实现Tomcat集群的配置,以及如何利用Terracotta实现Ehcache的集群配置。通过这种方式,可以有效提高Web应用的稳定性和性能,同时也能更好地应对高并发场景。需要注意的是...

    Spring整合Ecache

    EhCache的分布式缓存有传统的RMI,1.5版的JGroups,1.6版的JMS。分布式缓存主要解决集群环境中不同的服务器间的数据的同步问题。 使用Spring的AOP进行整合,可以灵活的对方法的返回结果对象进行缓存

Global site tag (gtag.js) - Google Analytics