当前位置:首页 > 科技  > 软件

玩转Redis!非常强大的Redisson分布式集合,少写60%代码

来源: 责编: 时间:2024-06-05 17:39:58 219观看
导读环境:SpringBoot2.7.18+Redis6.2.6+Redisson3.18.01. 简介Redisson 是 Redis Java 客户端和实时数据平台。它为使用 Redis 提供了更方便、更简单的方法。Redisson 对象提供了关注点分离功能,可让你专注于数据建模和应用

环境:SpringBoot2.7.18+Redis6.2.6+Redisson3.18.0WmQ28资讯网——每日最新资讯28at.com

1. 简介

Redisson 是 Redis Java 客户端和实时数据平台。它为使用 Redis 提供了更方便、更简单的方法。Redisson 对象提供了关注点分离功能,可让你专注于数据建模和应用逻辑。WmQ28资讯网——每日最新资讯28at.com

在Java中,为我们提供了丰富的集合类,如List、Set、Map等,这些集合类在单机应用或单个JVM进程中是非常强大和有效的工具。然而,在分布式系统下,数据需要在多个JVM进程或节点之间共享和同步。为实现这一目标Redisson提供了许多分布式集合实现,如RList、RSet、RMap等,这些集合类能够在多个Redis节点之间无缝地共享数据。通过使用Redisson,开发者可以像使用传统Java集合类一样,在分布式系统中进行数据的增删改查操作,而无需担心数据在不同节点之间的同步和一致性问题。WmQ28资讯网——每日最新资讯28at.com

2. 实战案例

2.1 Map集合

基于 Redis 的 Java 分布式 Map 对象实现了 ConcurrentMap 接口。该对象是完全线程安全的。WmQ28资讯网——每日最新资讯28at.com

  • RMap类关系
public interface RMap<K, V> extends ConcurrentMap<K, V>, ...{}

接下来所有操作都是基于RedissonClient对象WmQ28资讯网——每日最新资讯28at.com

@Resourceprivate RedissonClient redisson ;
  • 同步存数据
RMap<String, User> map = redisson.getMap("user-list");User preValue = map.put("1", new User(2L, "张三2", 22)) ;User value = map.putIfAbsent("2", new User(2L, "李四", 33));
  • 快速存数据

如果你不需要返回上一个值(旧值)建议使用相应fast*方法WmQ28资讯网——每日最新资讯28at.com

RMap<String, User> map = redisson.getMap("user-list");map.fastPut("1", new User(2L, "张三2", 22));map.fastPutIfAbsent("2", new User(2L, "李四", 33));map.fastRemove("1") ;

以上操作不会返回对应key之前的旧值。WmQ28资讯网——每日最新资讯28at.com

  • 异步存数据
RFuture<User> f1 = map.putAsync("1", new User(2L, "张三2", 22)) ;RFuture<Boolean> f2 = map.fastPutAsync("2", new User(2L, "李四", 33)) ;RFuture<Long> f3 = map.fastRemoveAsync("2") ;

以上操作对应Redis数据结构。WmQ28资讯网——每日最新资讯28at.com

HASH数据结构HASH数据结构WmQ28资讯网——每日最新资讯28at.com

  • Map集合中key绑定Lock

上面得知,Map保存的数据是hash数据结构,我们可以将每一个key绑定到对应的Lock/ReadWriteLock/Semaphore/CountDownLatch。WmQ28资讯网——每日最新资讯28at.com

RMap<String, User> map = redisson.getMap("user-list") ;RLock lock = map.getLock(key) ;lock.lock() ;try {  System.out.printf("当前线程: %s, 当前时间: %d%n", Thread.currentThread().getName(), System.currentTimeMillis()) ;  TimeUnit.SECONDS.sleep(3) ;} finally {  lock.unlock() ;}
  • 本地缓存

用于加快读取操作速度,避免网络往返。它在 Redisson 端缓存地图条目,执行读取操作的速度是普通实现的 45 倍。支持本地缓存的地图对象实现了RLocalCachedMap,它扩展了 java.util.concurrent.ConcurrentMap 接口。该对象是完全线程安全的。WmQ28资讯网——每日最新资讯28at.com

// 配置缓存策略final LocalCachedMapOptions<String, User> LOCAL_CACHE = LocalCachedMapOptions.<String, User>defaults()      // 缓存大小      .cacheSize(200)      // 缓存模式      .storeMode(StoreMode.LOCALCACHE_REDIS)      // 删除策略      .evictionPolicy(EvictionPolicy.LRU) ;// 获取指定key本地缓存      RLocalCachedMap<String,User> localCachedMap = redisson.getLocalCachedMap("user-list", LOCAL_CACHE) ;User user = localCachedMap.get("1") ;

本地缓存实例对象同样支持fast*及异步方式,这里不再赘述。WmQ28资讯网——每日最新资讯28at.com

  • 事件监听

Redisson 允许为每个 RMap 对象绑定监听器,RMap 对象允许跟踪数据上的跟踪事件。如下表,监听类及事件WmQ28资讯网——每日最新资讯28at.com

图片图片WmQ28资讯网——每日最新资讯28at.com

如下示例:WmQ28资讯网——每日最新资讯28at.com

RMap<String, User> map = redisson.getMap("user-list");int deletedListener = map.addListener(new DeletedObjectListener() {  @Override  public void onDeleted(String name) {    // ...  }});int expredListener = map.addListener(new ExpiredObjectListener() {  @Override  public void onExpired(String name) {    // ...  }});int putListener = map.addListener(new MapPutListener() {  @Override  public void onPut(String name) {    // ...  }});int removeListener = map.addListener(new MapRemoveListener() {  @Override  public void onRemove(String name) {    // ...  }});// 删除监听器map.removeListener(listenerId) ; // removeListener, putListener ...

以上是关于Map集合的常用操作。WmQ28资讯网——每日最新资讯28at.com

2.2 Set集合

基于 Redis 的 Java Set 对象实现了 java.util.Set 接口。该对象完全线程安全。通过元素状态比较保持元素的唯一性。Redis 将集合大小限制为 4 294 967 295 个元素。Redis 使用序列化状态检查值的唯一性,而不是值的 hashCode()/equals() 方法。WmQ28资讯网——每日最新资讯28at.com

  • RSet类关系
public interface RSet<V> extends Set<V>,...{}
  • 基本操作
RSet<User> set = redisson.getSet("user-set");set.add(new User(1L, "张三", 33)) ;set.add(new User(2L, "李四", 55)) ;

Redis中存储使用的数据结构:WmQ28资讯网——每日最新资讯28at.com

图片WmQ28资讯网——每日最新资讯28at.com

RSet使用Set集合。与RMap一样,RSet也支持同步异步方式操作数据。WmQ28资讯网——每日最新资讯28at.com

RFuture<Boolean> f1 = set.addAsync(new User(1L, "张三", 33)) ;RFuture<Boolean> f2 = set.addAsync(new User(2L, "李四", 55)) ;
  • 绑定Lock操作
RSet<User> set = redisson.getSet("user-set") ;RLock lock = set.getLock(new User(1L, "张三", 33)) ;lock.lock() ;try {  // ...} finally {  lock.unlock() ;}
  • 删除策略

当前的Redis实现没有设置值删除功能。因此,过期的数据会被org.redisson.eviction.EvictionScheduler清除。它一次性删除300个过期条目。如果clean task每次删除300项,它将每秒执行一次(最小执行延迟)。但如果当前的过期值小于前一个,则执行延迟将增加1.5倍。WmQ28资讯网——每日最新资讯28at.com

RSetCache<User> set = redisson.getSetCache("user-set") ;set.add(new User(3L, "阴阳路", 66), 180L, TimeUnit.SECONDS) ;
  • 事件监听

与Map一样Set也有对应的事件监听,详细查看Map中对应的说明。WmQ28资讯网——每日最新资讯28at.com

  • Set排序

基于 Redis 的 Java 分布式 SortedSet 实现了 java.util.SortedSet 接口。该对象线程安全。它使用比较器对元素进行排序并保持唯一性。对于字符串数据类型,建议使用 LexSortedSet 对象,以提高性能。WmQ28资讯网——每日最新资讯28at.com

RSortedSet<Integer> set = redisson.getSortedSet("set-sort") ;// 这里不可以写成lambda表达式:(o1, o2) -> Integer.compare(o1, o2)set.trySetComparator(new Comparator<Integer>() {  @Override  public int compare(Integer o1, Integer o2) {    return o1 > o2 ? 1 : (o1 < o2 ? -1 : 0)  ;  }}) ;set.add(3) ;set.add(1) ;set.add(2) ;

redis中生成如下2个key:WmQ28资讯网——每日最新资讯28at.com

图片图片WmQ28资讯网——每日最新资讯28at.com

set-sort对应的值:WmQ28资讯网——每日最新资讯28at.com

图片图片WmQ28资讯网——每日最新资讯28at.com

2.3 List集合

基于 Redis 的 Java 分布式 List 对象实现了 java.util.List 接口。它按插入顺序保存元素。它有 Async、Reactive 和 RxJava3 接口。Redis 限制列表大小为 4 294 967 295 个元素。WmQ28资讯网——每日最新资讯28at.com

  • RList类关系
public interface RList<V> extends List<V>, ... {}
  • 基本操作
RList<User> list = redisson.getList("user-list");User user = new User(1L, "张三", 10);list.add(user) ;User ret = list.get(0) ;System.out.println("ret = " + ret) ;list.remove(user) ;
  • 事件监听
RList<User> list = redisson.getList("user-list") ;list.addListener(new ExpiredObjectListener() {  @Override  public void onExpired(String name) {    // ...  }}) ;// 其它事件/** * DeletedObjectListener * ListAddListener * ListInsertListener * ListSetListener * ListRemoveListener * ListTrimListener */

2.4 Queue队列

基于 Redis 的 Java 分布式无界队列对象,实现了 java.util.Queue 接口。该对象是完全线程安全的。它有 Async、Reactive 和 RxJava3 接口。WmQ28资讯网——每日最新资讯28at.com

  • RQueue类关系
public interface RQueue<V> extends Queue<V>, ... {}
  • 基本操作
RQueue<User> queue = redisson.getQueue("user-queue");queue.add(new User()) ;// 获取但不删除User u1 = queue.peek() ;// 获取并删除User u2 = queue.poll() ;

redis使用的数据结构:WmQ28资讯网——每日最新资讯28at.com

图片图片WmQ28资讯网——每日最新资讯28at.com

  • 事件监听
RQueue<User> queue = redisson.getQueue("user-queue") ;queue.addListener(new ExpiredObjectListener() {  @Override  public void onExpired(String name) {    // ...  }}) ;// 其它事件/** * ListAddListener * ListInsertListener * ListRemoveListener */

2.5 阻塞队列

基于Redis 的Java 分布式无界BlockingQueue对象,实现了 java.util.concurrent.BlockingQueue接口。该对象是完全线程安全的。它有 Async、Reactive 和 RxJava3 接口。WmQ28资讯网——每日最新资讯28at.com

  • 类关系
public interface RBlockingQueue<V> extends BlockingQueue<V>, ... {}
  • 基本操作
RBlockingQueue<User> queue = redisson.getBlockingQueue("user-blockqueue");queue.offer(new User(1L, "哈哈", 22)) ;// queue.offer(new User(2L, "嘿嘿", 33)) ;User u1 = queue.peek() ;User u2 = queue.poll() ;// 这里会被阻塞,最多等待10s队列中有元素则直接返回User u3 = queue.poll(10, TimeUnit.SECONDS) ;

对应redis使用的数据结构:WmQ28资讯网——每日最新资讯28at.com

图片图片WmQ28资讯网——每日最新资讯28at.com

2.6 有界阻塞队列

大致使用用途上面一致:WmQ28资讯网——每日最新资讯28at.com

RBoundedBlockingQueue<SomeObject> queue = redisson.getBoundedBlockingQueue("user-capacity-queue");// 设置容量大小queue.trySetCapacity(2);queue.offer(new User(1L, "张三", 20));queue.offer(new User(2L, "李四", 10));

Redisson提供了很多分布式的队列实现,如还有双端队列,优先级队列等,这里就不一一展示了。WmQ28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-92105-0.html玩转Redis!非常强大的Redisson分布式集合,少写60%代码

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Python 中 20 个鲜为人知的字符串函数

下一篇: 为什么要限流?常见的限流算法有哪些?

标签:
  • 热门焦点
  • 俄罗斯:将审查iPhone等外国公司设备 保数据安全

    iPhone和特斯拉都属于在各自领域领头羊的品牌,推出的产品也也都是数一数二的,但对于一些国家而言,它们的产品可靠性和安全性还是在限制范围内。近日,俄罗斯联邦通信、信息技术
  • 帅气纯真少年!日本最帅初中生选美冠军出炉

    日本第一帅哥初一生选美大赛冠军现已正式出炉,冠军是来自千叶县的宗田悠良。日本一直热衷于各种选美大赛,从&ldquo;最美JK&rdquo;起到&ldquo;最美女星&r
  • 《英雄联盟》夏季赛总决赛今日开打!JDG对阵LNG首发名单来了 Knight:准备三连冠

    8月5日消息,今日17:00,《英雄联盟》2023LPL夏季赛总决赛将正式开打,由JDG对阵LNG。对两支队伍来说,这场比赛不仅要争夺夏季赛冠军,更要决定谁才是LPL赛区一
  • 如何通过Python线程池实现异步编程?

    线程池的概念和基本原理线程池是一种并发处理机制,它可以在程序启动时创建一组线程,并将它们置于等待任务的状态。当任务到达时,线程池中的某个线程会被唤醒并执行任务,执行完任
  • 2023年,我眼中的字节跳动

    此时此刻(2023年7月),字节跳动从未上市,也从未公布过任何官方的上市计划;但是这并不妨碍它成为中国最受关注的互联网公司之一。从2016-17年的抖音强势崛起,到2018年的&ldquo;头腾
  • ESG的面子与里子

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之三伏大幕拉起,各地高温预警不绝,但处于厄尔尼诺大&ldquo;烤&rdquo;之下的除了众生,还有各大企业发布的ESG报告。ESG是&ldquo;环境保
  • 当家的盒马,加速谋生

    来源 | 价值星球Planet作者 | 归去来自己&ldquo;当家&rdquo;的盒马,开始加速谋生了。据盒马官微消息,盒马计划今年开放生鲜供应链,将其生鲜商品送往食堂。目前,盒马在上海已经与
  • 携众多高端产品亮相ChinaJoy,小米带来一场科技与人文的视听盛宴

    7月28日,全球数字娱乐领域最具知名度与影响力的年度盛会中国国际数码互动娱乐展览会(简称ChinaJoy)在上海新国际博览中心盛大开幕。作为全球领先的科
  • iQOO 11S评测:行业唯一的200W标准版旗舰

    【Techweb评测】去年底,iQOO推出了“电竞旗舰”iQOO 11系列,作为一款性能强机,该机不仅全球首发2K 144Hz E6全感屏,搭载了第二代骁龙8平台及144Hz电竞
Top