Redis和Ehcache的区别

Redis是一款独立运行的缓存系统,适用于集群和分布式环境,而Ehcache是Java应用内的缓存,适合单应用且操作简单。Redis提供socket访问,处理分布式场景更优,Ehcache则在内存中快速缓存,适用于小型应用。两者各有侧重,选择需根据实际需求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Redis
属于独立的运行程序,需要单独安装后,使用JAVA中的Jedis来操纵。因为它是独立,所以如果你写个单元测试程序,放一些数据在Redis中,然后又写一个程序去拿数据,那么是可以拿到这个数据的。

Ehcache
与Redis明显不同,它与java程序是绑在一起的,java程序活着,它就活着。譬如,写一个独立程序放数据,再写一个独立程序拿数据,那么是拿不到数据的。只能在独立程序中才能拿到数据。ehcache是Hibernate中默认的CacheProvider,直接在jvm虚拟机中缓存,速度快,效率高;但是缓存共享麻烦,集群分布式应用不方便。缓存数据有两级:内存和磁盘,因此无需担心容量问题,提供Hibernate的缓存实现 。

Ehcache特点

  1. 够快
    Ehcache的发行有一段时长了,经过几年的努力和不计其数的性能测试,Ehcache终被设计于large, high concurrency systems.

  2. 够简单
    开发者提供的接口非常简单明了,从Ehcache的搭建到运用运行仅仅需要的是你宝贵的几分钟。其实很多开发者都不知道自己用在用Ehcache,Ehcache被广泛的运用于其他的开源项目
    比如:hibernate

3.够袖珍
关于这点的特性,官方给了一个很可爱的名字small foot print ,一般Ehcache的发布版本不会到2M,V 2.2.3 才 668KB。

  1. 够轻量
    核心程序仅仅依赖slf4j这一个包,没有之一!

5.好扩展
Ehcache提供了对大数据的内存和硬盘的存储,最近版本允许多实例、保存对象高灵活性、提供LRU、LFU、FIFO淘汰算法,基础属性支持热配置、支持的插件多

6.监听器
缓存管理器监听器 (CacheManagerListener)和 缓存监听器(CacheEvenListener),做一些统计或数据一致性广播挺好用的

如何使用?
够简单就是Ehcache的一大特色,自然用起来just so easy!

贴一段基本使用代码

CacheManager
 manager 
=
 
CacheManager
.
newInstance
(
"src/config/ehcache.xml"
);

Ehcache
 cache 
=
 
new
 
Cache
(
"testCache"
,
 
5000
,
 
false
,
 
false
,
 
5
,
 
2
);

cacheManager
.
addCache
(
cache
);



 
代码中有个
ehcache
.
xml
文件,现在来介绍一下这个文件中的一些属性

       name
:缓存名称。

       maxElementsInMemory
:缓存最大个数。

       eternal
:对象是否永久有效,一但设置了,
timeout
将不起作用。

       timeToIdleSeconds
:设置对象在失效前的允许闲置时间(单位:秒)。仅当
eternal
=
false
对象不是永久有效时使用,可选属性,默认值是
0
,也就是可闲置时间无穷大。

       timeToLiveSeconds

:设置对象在失效前允许存活时间,最大时间介于创建时间和失效时间之间。仅当

eternal
=
false
对象不是永久有效时使用,默认是
0.
,也就是对象存活时
 
间无穷大。

       overflowToDisk
:当内存中对象数量达到
maxElementsInMemory
时,
Ehcache
将会对象写到磁盘中。

       diskSpoolBufferSizeMB
:这个参数设置
DiskStore
(磁盘缓存)的缓存区大小。默认是
30MB
。每个
Cache
都应该有自己的一个缓冲区。

       maxElementsOnDisk
:硬盘最大缓存个数。

       diskPersistent
:是否缓存虚拟机重启期数据
 
Whether
 the disk store persists between restarts of the 
Virtual
 
Machine
.
 
The
 
default
 value 
is
 
false
.

       diskExpiryThreadIntervalSeconds
:磁盘失效线程运行时间间隔,默认是
120
秒。

       memoryStoreEvictionPolicy
:当达到
maxElementsInMemory
限制时,
Ehcache
将会根据指定的策略去清理内存。默认策略是
LRU
。你可以设置为
 FIFO
或是
LFU
。

       clearOnFlush
:内存数量最大时是否清除。

redis是通过socket访问到缓存服务,效率比ecache低,比数据库要快很多,处理集群和分布式缓存方便,有成熟的方案。

如果是单个应用或者对缓存访问要求很高的应用,用ehcache。如果是大型系统,存在缓存共享、分布式部署、缓存内容很大的,建议用redis。


如果大家对于学习Java有任何问题(学习方法,学习效率,如何就业),可以随时来咨询我,这是我的Java交流学习扣扣群:六三零,四七三,七一 一。 多多交流问题,互帮互助,群里有不错的学习教程和开发工具。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值