Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >为什么要在分布式系统中使用缓存?

为什么要在分布式系统中使用缓存?

作者头像
Java技术栈
发布于 2019-07-08 02:13:09
发布于 2019-07-08 02:13:09
1.3K00
代码可运行
举报
文章被收录于专栏:Java技术栈Java技术栈
运行总次数:0
代码可运行

来自 ImportNew,作者:唐尤华 为什么要在 Java 分布式应用程序中使用缓存?

在提高应用程序速度和性能上,每一毫秒都很重要。根据谷歌的一项研究,假如一个网站在3秒钟或更短时间内没有加载成功,会有 53% 的手机用户会离开。

缓存是让分布式应用程序加速的重要技术之一。存储的信息越接近 CPU,访问速度就越快。从 CPU 缓存中加载数据比从 RAM 中加载要快得多,比从硬盘或网络上加载要快得多得多。

要存储经常访问的数据,分布式应用程序需要在多台机器中维护缓存。分布式缓存是降低分布式应用程序延迟、提高并发性和可伸缩性的一种重要策略。

Redis 是一种流行的开源内存数据存储,可用作数据库、缓存或消息代理。由于是从内存而非磁盘加载数据,Redis 比许多传统的数据库解决方案更快。

然而,对开发者来说让 Redis 分布式缓存正确工作是一个巨大挑战。例如,必须谨慎处理本地缓存失效,即替换或删除缓存条目。每次更新或删除存储计算机本地缓存中的信息时,必须更新分布式缓存系统所有计算机内存中的缓存。

好消息是,有一些类似 Redisson 这样的 Redis 框架,可以帮助构建应用程序所需的分布式缓存。

下一节将讨论 Redisson 中分布式缓存的三个重要实现:Maps、Spring Cache 和 JCache。

1. Redisson 分布式缓存

Redisson 是一个基于 Redis 的框架,用 Java 实现了一个 Redis 包装器(wrapper)和接口。Redisson 包含许多常见的 Java 类,例如分布式对象、分布式服务、分布式锁和同步器,以及分布式集合。正如下面即将介绍的,其中一些接口同时支持分布式缓存和本地缓存。

2. Map

Map 是 Java 最有用的集合之一。推荐:HashMap 和 Hashtable 的 6 个区别。Redisson 提供了一个名为 RMap 的 Java Map 实现,支持本地缓存。

如果希望执行多个读操作或网络环回(roundtrip),应使用支持本地缓存的 RMap。通过本地存储 Map 数据,RMap 比不启用本地缓存时快45倍。通用分布式缓存使用 RMapCache,本地缓存使用 RLocalCachedMap。

Redis 引擎自身能够执行缓存,不需要在客户端执行代码。然而,虽然本地缓存能显著提高读取速度,但需要由开发人员维护,并且可能需要一些开发工作。Redisson 为开发人员提供了 RLocalCachedMap 对象,让本地缓存实现起来更容易。

下面的代码展示了如何初始化 RMapCache 对象:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
RMapCache<String, SomeObject> map = redisson.getMapCache("anyMap");
map.put("key1", new SomeObject(), 10, TimeUnit.MINUTES, 10, TimeUnit.SECONDS);

上面的代码将字符串 "key1" 放到 RMapCache 中,并与 SomeObject() 关联。然后它指定了两个参数,TTL设为10分钟、最大空闲时间10秒。

当不再需要时,应销毁 RMapCache 对象:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
map.destroy();

Redisson 关闭后不用再做销毁操作。

3. Spring Cache

Spring 是一个用于构建企业级 Web 应用程序的 Java 框架,也提供了缓存支持。

Redisson 包含了 Spring 缓存功能,提供两个对象: RedissonSpringCacheManager 和 RedissonSpringLocalCachedCacheManager。 RedissonSpringLocalCachedCacheManager 支持本地缓存。

下面是一个 RedissonSpringLocalCachedCacheManager 对象的示例配置:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
@Configuration
@ComponentScan
@EnableCaching
public static class Application {
    @Bean(destroyMethod="shutdown")
    RedissonClient redisson() throws IOException {
        Config config = new Config();
        config.useClusterServers()
                .addNodeAddress("127.0.0.1:7004", "127.0.0.1:7001");
        return Redisson.create(config);
    }
    @Bean
    CacheManager cacheManager(RedissonClient redissonClient) {
        Map<String, CacheConfig> config = new HashMap<String, CacheConfig>();
        // 新建 "testMap" 缓存:ttl=24分钟,maxIdleTime=12分钟
        config.put("testMap", new CacheConfig(24*60*1000, 12*60*1000));
        return new RedissonSpringCacheManager(redissonClient, config);
    }
}

此外,还可以读取 JSON 或 YAML 文件配置 RedissonSpringCacheManager。

与 RMaps 一样,每个 RedissonSpringCacheManager 实例都有两个重要参数: ttl(生存时间)和 maxIdleTime。如果这些参数设为0或者没有定义,那么数据将无限期地保留在缓存中。

4. JCache

JCache 是一个 Java 缓存 API,允许开发人员从缓存临时存储、检索、更新和删除对象。

Redisson 提供了 Redis 的 JCache API 实现。下面是在 Redisson 中使用默认配置调用 JCache API 的示例:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
MutableConfiguration<String, String> config = new MutableConfiguration<>();
CacheManager manager = Caching.getCachingProvider().getCacheManager();
Cache<String, String> cache = manager.createCache("namedCache", config);

此外,还可以使用自定义配置文件、Redisson Config 对象或 Redisson RedissonClient 对象配置 JCache。例如,下面的代码使用自定义 Redisson 配置来调用 JCache:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
MutableConfiguration<String, String> jcacheConfig = new MutableConfiguration<>();
Config redissonCfg = ...
Configuration<String, String> config = RedissonConfiguration.fromConfig(redissonCfg, jcacheConfig);
CacheManager manager = Caching.getCachingProvider().getCacheManager();
Cache<String, String> cache = manager.createCache("namedCache", config);

Redisson 的 JCache 实现已经通过 JCache TCK 的所有测试。你也可以自行验证。

让我们愉快地使用缓存吧!

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-02-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Java技术栈 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
谷粒商城-高级篇(分布式锁与缓存)
当进行压力测试时后期后出现堆外内存溢出OutOfDirectMemoryError
OY
2022/03/20
1.2K0
谷粒商城-高级篇(分布式锁与缓存)
最强 Java Redis 客户端
来源:dzone.com/articles/java-distributed-caching-in-redis
乔戈里
2019/12/24
1.9K0
一起来学redis redission
redis 的客户端有jedis、lettuce、redission;我个人比较推荐的是redission,因为它的分布式锁和缓存实在是太优秀了。Redisson采用了基于NIO的Netty框架,封装了大家常用的集合类以及原子类、锁等工具。
六个核弹
2022/12/23
2.1K0
一起来学redis redission
浅谈缓存与分布式锁
对于一个大型网站而言,每天的访问量是巨大的,尤其遇到某些特定的时间点,比如电商平台的购物节、教育平台开学季。当在某个时间点遇到过量的并发时,往往会压垮服务器导致网站崩溃,因此,网站对于高并发的处理是至关重要的,其中缓存起着举足轻重的作用。对于一些不经常变化,或者热度很高的数据,可以将其存入缓存,此时当用户访问时将直接读取缓存而不查询数据库,从而大大提高了网站的吞吐量。
wangweijun
2022/01/10
2090
dubbo 缓存的使用和实现解析
dubbo缓存主要实现,对方法调用结果的缓存。 在服务消费方和提供方都可以配置使用缓存。 以消费方为例,可以配置全局缓存策略,这样所有服务引用都启动缓存 <dubbo:consumer cache="lru"/> 可以对某个服务引用配置缓存策略 <dubbo:reference id="demoService"   interface="demo.dubbo.api.DemoService" cache="lru"  > 也支持对单个方法启用缓存策略 <dubbo:reference id="
技术蓝海
2018/04/26
2.2K0
dubbo 缓存的使用和实现解析
Java一分钟之-Ehcache:分布式缓存系统
Ehcache是Java领域内广受欢迎的开源缓存解决方案,不仅支持本地缓存,还具备分布式缓存的能力,适用于多种应用场景,从简单快速的内存缓存到复杂的分布式缓存集群。本文旨在深入浅出地介绍Ehcache在分布式环境下的使用、常见问题、易错点及其规避策略,并通过代码示例辅助理解,帮助开发者高效利用Ehcache提升应用性能。
Jimaks
2024/06/17
6040
Redis集群实现分布式锁的正确方式
上文我们介绍的 Redis实现分布式锁的正确方式 是 redis 单机的方式,所以本篇要基于 redis 集群做分布式锁,我们使用 Redisson
胖虎
2019/06/26
7.8K0
Redis集群实现分布式锁的正确方式
玩转Spring Cache --- 整合进程缓存之王Caffeine Cache和Ehcache3.x【享学Spring】
前面文章大篇幅详细讲解了Spring Cache缓存抽象、三大缓存注解的工作原理等等。若是细心的小伙伴会发现:讲解时的Demo我使用的缓存实现方案均是Spring默认提供的:ConcurrentMapCache。使用它的原因是它是spring-context内置的,无需额外导包就能使用,非常的方便~
YourBatman
2019/09/03
8.1K0
玩转Spring Cache --- 整合进程缓存之王Caffeine Cache和Ehcache3.x【享学Spring】
JAVA中使用最广泛的本地缓存?Ehcache的自信从何而来2 —— Ehcache的各种项目集成与使用初体验
在上一篇文章《JAVA中使用最广泛的本地缓存?Ehcache的自信从何而来 —— 感受来自Ehcache的强大实力》中,介绍了Ehcache所具有的核心优秀特性,如数据持久化、多级缓存、集群能力等等。所谓纸上得来终觉浅、绝知此事要躬行,接下来我们就一起动手实践下,在项目中集成Ehcache并体验Ehcache的各种常见用法。
是Vzn呀
2023/01/05
1.6K0
redisson应用之分布式对象
每个Redisson对象实例都会有一个与之对应的Redis数据实例,可以通过调用getName方法来取得Redis数据实例的名称(key)。
kl博主
2023/11/18
2440
redisson应用之分布式集合
Redisson的分布式Map结构的RMap Java对象实现了java.util.concurrent.ConcurrentMap接口和java.util.Map接口。同时还保持了元素的插入顺序。该对象的最大容量受Redis限制,最大元素数量是4 294 967 295个。
kl博主
2023/11/18
5910
玩转Spring Cache --- 整合分布式缓存Redis Cache(使用Lettuce、使用Spring Data Redis)【享学Spring】
最近都在聊Spring的缓存抽象Spring Cache,上篇文章深入介绍了Spring Cache集成进程缓存的第三方组件如Caffeine、Ehcache,若对此篇文章感兴趣,可移步观看:【小家Spring】玩转Spring Cache — 整合进程缓存之王Caffeine Cache和Ehcache3.x
YourBatman
2019/09/03
5.9K0
玩转Spring Cache --- 整合分布式缓存Redis Cache(使用Lettuce、使用Spring Data Redis)【享学Spring】
构建分布式缓存方案:Redis与Spring Cache的最佳实践
在现代的应用开发中,缓存是提高性能和扩展性的关键因素之一。Spring框架提供了Spring Cache模块,用于简化缓存的使用和管理。而Redis作为一个高性能的内存缓存数据库,也广泛应用于分布式缓存场景。本文将介绍如何结合Redis和Spring Cache,构建高效可靠的分布式缓存方案,并分享一些最佳实践。
王也518
2023/12/22
7540
【第十二篇】商城系统-分布式锁的应用
setNX: setNX(key,value) :如果key不存在那么就添加key的值,否则添加失败,Redisson
用户4919348
2022/10/04
2390
【第十二篇】商城系统-分布式锁的应用
Java缓存深入理解
对于缓存大家都不会陌生,但如何正确和合理的使用缓存还是需要一定的思考,本文将基于Java技术栈对缓存做一个相对详细的介绍,内容分为基本概念、本地缓存、远程缓存和分布式缓存集群几个部分,重点在于理解缓存
用户1216676
2018/01/24
10.6K1
redisson分布式锁使用
Redisson 是一个高级的分布式协调 Redis 客服端,能帮助用户在分布式环境中轻松实现一些 Java 的对象 (Bloom filter, BitSet, Set, SetMultimap, ScoredSortedSet, SortedSet, Map, ConcurrentMap, List, ListMultimap, Queue, BlockingQueue, Deque, BlockingDeque, Semaphore, Lock, ReadWriteLock, AtomicLong, CountDownLatch, Publish / Subscribe, HyperLogLog)。
JavaEdge
2021/02/23
5340
redisson分布式锁使用
用Redis实现分布式锁以及redission使用
前言:分布式环境有很多问题,比如你前一个请求访问的是服务器A,第二个请求访问到了服务器B,就会发生并发重复插入问题,这个时候需要依赖单点来实现分布锁,而redis就是。
王念博客
2019/07/24
1.5K0
Java redis并发读写锁,使用Redisson实现分布式锁
在分布式系统中,处理并发读写操作是一个常见的挑战。许多应用程序需要协调并发访问共享资源,以确保数据的一致性和可靠性。为了解决这个问题,我们可以使用分布式锁来同步并发读写操作。本文将介绍如何使用Redisson实现分布式锁,并在Java应用程序中实现并发读写锁。
大盘鸡拌面
2024/02/10
7770
SpringBoot 操作 Redis的各种实现(以及Jedis、Redisson、Lettuce的区别比较)
共同点:都提供了基于Redis操作的Java API,只是封装程度,具体实现稍有不同。
架构师修炼
2021/09/10
4K0
SpringBoot 操作 Redis的各种实现(以及Jedis、Redisson、Lettuce的区别比较)
Spring cache 使用Redis做分布式缓存
DemoApplication启动类头部加入@EnableCaching开启缓存 redis.config配置
阿提说说
2022/12/02
5620
推荐阅读
相关推荐
谷粒商城-高级篇(分布式锁与缓存)
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档