Redis 分布式缓存 Java 框架

为什么要在 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 最有用的集合之一。Redisson 提供了一个名为 RMap 的 Java Map 实现,支持本地缓存。

 

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

 

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

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

 

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 对象:

 

map.destroy();

 

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

 

3. Spring Cache

 

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

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

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

 

@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 的示例:

 

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:

 

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 的所有测试。你也可以自行验证。

 

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

转载于:https://www.cnblogs.com/dz11/p/10413551.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot是一个开发Java应用程序的框架,它简化了Java应用程序的开发和部署过程。同时,它提供了一系列的开箱即用的功能模块,使得开发者可以轻松地构建分布式系统。 STOMP(简单文本导向的消息传递协议)是一种基于文本的协议,用于定义Web应用程序之间的通信方式。它允许开发者使用不同的编程语言编写的客户端和服务器之间进行实时的双向通信。 STOMP是一种扩展性的协议,可以与消息队列(如RabbitMQ、ActiveMQ等)以及WebSocket等协议一起使用。 Redis是一种开源的内存数据结构存储系统,它可以用作数据库、缓存和消息中间件。Redis支持多种数据结构(如字符串、哈希表、列表、集合等),并提供了丰富的命令集合,可以用于实现分布式系统中的各种需求。 结合三者,我们可以实现一个基于Spring Boot、STOMP和Redis的分布式聊天应用程序。首先,我们可以使用Spring Boot搭建一个Web应用程序,通过WebSocket来实现实时双向通信。然后,使用STOMP协议来定义消息的格式和交互方式。通过Redis存储消息的发布和订阅机制,我们可以实现多个节点之间的消息传递和广播。 在这个分布式聊天应用程序中,当一个用户发送一条消息时,消息会被发送到Redis中的一个频道或主题。其他节点上的订阅者会接收到这条消息,并进行相应的处理。用户可以通过订阅特定的频道或主题来接收感兴趣的消息,并通过WebSocket将消息实时地展示给用户。 通过使用Spring Boot、STOMP和Redis,我们可以简单快速地搭建一个强大的分布式聊天应用程序。这种架构允许我们扩展应用程序并提供高可用性和可扩展性。同时,使用Redis作为消息存储也可以提高系统的性能和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值