日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

玩轉Redis!非常強大的Redisson分布式集合,少寫60%代碼

來源: 責編: 時間:2024-06-05 17:39:58 221觀看
導讀環境:SpringBoot2.7.18+Redis6.2.6+Redisson3.18.01. 簡介Redisson 是 Redis Java 客戶端和實時數據平臺。它為使用 Redis 提供了更方便、更簡單的方法。Redisson 對象提供了關注點分離功能,可讓你專注于數據建模和應用

環境:SpringBoot2.7.18+Redis6.2.6+Redisson3.18.02V028資訊網——每日最新資訊28at.com

1. 簡介

Redisson 是 Redis Java 客戶端和實時數據平臺。它為使用 Redis 提供了更方便、更簡單的方法。Redisson 對象提供了關注點分離功能,可讓你專注于數據建模和應用邏輯。2V028資訊網——每日最新資訊28at.com

在Java中,為我們提供了豐富的集合類,如List、Set、Map等,這些集合類在單機應用或單個JVM進程中是非常強大和有效的工具。然而,在分布式系統下,數據需要在多個JVM進程或節點之間共享和同步。為實現這一目標Redisson提供了許多分布式集合實現,如RList、RSet、RMap等,這些集合類能夠在多個Redis節點之間無縫地共享數據。通過使用Redisson,開發者可以像使用傳統Java集合類一樣,在分布式系統中進行數據的增刪改查操作,而無需擔心數據在不同節點之間的同步和一致性問題。2V028資訊網——每日最新資訊28at.com

2. 實戰案例

2.1 Map集合

基于 Redis 的 Java 分布式 Map 對象實現了 ConcurrentMap 接口。該對象是完全線程安全的。2V028資訊網——每日最新資訊28at.com

  • RMap類關系
public interface RMap<K, V> extends ConcurrentMap<K, V>, ...{}

接下來所有操作都是基于RedissonClient對象2V028資訊網——每日最新資訊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*方法2V028資訊網——每日最新資訊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之前的舊值。2V028資訊網——每日最新資訊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數據結構。2V028資訊網——每日最新資訊28at.com

HASH數據結構HASH數據結構2V028資訊網——每日最新資訊28at.com

  • Map集合中key綁定Lock

上面得知,Map保存的數據是hash數據結構,我們可以將每一個key綁定到對應的Lock/ReadWriteLock/Semaphore/CountDownLatch。2V028資訊網——每日最新資訊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 接口。該對象是完全線程安全的。2V028資訊網——每日最新資訊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*及異步方式,這里不再贅述。2V028資訊網——每日最新資訊28at.com

  • 事件監聽

Redisson 允許為每個 RMap 對象綁定監聽器,RMap 對象允許跟蹤數據上的跟蹤事件。如下表,監聽類及事件2V028資訊網——每日最新資訊28at.com

圖片圖片2V028資訊網——每日最新資訊28at.com

如下示例:2V028資訊網——每日最新資訊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集合的常用操作。2V028資訊網——每日最新資訊28at.com

2.2 Set集合

基于 Redis 的 Java Set 對象實現了 java.util.Set 接口。該對象完全線程安全。通過元素狀態比較保持元素的唯一性。Redis 將集合大小限制為 4 294 967 295 個元素。Redis 使用序列化狀態檢查值的唯一性,而不是值的 hashCode()/equals() 方法。2V028資訊網——每日最新資訊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中存儲使用的數據結構:2V028資訊網——每日最新資訊28at.com

圖片2V028資訊網——每日最新資訊28at.com

RSet使用Set集合。與RMap一樣,RSet也支持同步異步方式操作數據。2V028資訊網——每日最新資訊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倍。2V028資訊網——每日最新資訊28at.com

RSetCache<User> set = redisson.getSetCache("user-set") ;set.add(new User(3L, "陰陽路", 66), 180L, TimeUnit.SECONDS) ;
  • 事件監聽

與Map一樣Set也有對應的事件監聽,詳細查看Map中對應的說明。2V028資訊網——每日最新資訊28at.com

  • Set排序

基于 Redis 的 Java 分布式 SortedSet 實現了 java.util.SortedSet 接口。該對象線程安全。它使用比較器對元素進行排序并保持唯一性。對于字符串數據類型,建議使用 LexSortedSet 對象,以提高性能。2V028資訊網——每日最新資訊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:2V028資訊網——每日最新資訊28at.com

圖片圖片2V028資訊網——每日最新資訊28at.com

set-sort對應的值:2V028資訊網——每日最新資訊28at.com

圖片圖片2V028資訊網——每日最新資訊28at.com

2.3 List集合

基于 Redis 的 Java 分布式 List 對象實現了 java.util.List 接口。它按插入順序保存元素。它有 Async、Reactive 和 RxJava3 接口。Redis 限制列表大小為 4 294 967 295 個元素。2V028資訊網——每日最新資訊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 接口。2V028資訊網——每日最新資訊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使用的數據結構:2V028資訊網——每日最新資訊28at.com

圖片圖片2V028資訊網——每日最新資訊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 接口。2V028資訊網——每日最新資訊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使用的數據結構:2V028資訊網——每日最新資訊28at.com

圖片圖片2V028資訊網——每日最新資訊28at.com

2.6 有界阻塞隊列

大致使用用途上面一致:2V028資訊網——每日最新資訊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提供了很多分布式的隊列實現,如還有雙端隊列,優先級隊列等,這里就不一一展示了。2V028資訊網——每日最新資訊28at.com

本文鏈接:http://m.www897cc.com/showinfo-26-92105-0.html玩轉Redis!非常強大的Redisson分布式集合,少寫60%代碼

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: Python 中 20 個鮮為人知的字符串函數

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

標簽:
  • 熱門焦點
  • Mate60手機殼曝光 致敬自己的經典設計

    8月3日消息,今天下午博主數碼閑聊站帶來了華為Mate60的第三方手機殼圖,可以讓我們在真機發布之前看看這款華為全新旗艦的大致輪廓。從曝光的圖片看,Mate 60背后攝像頭面積依然
  • 小米降噪藍牙耳機Necklace分享:聽一首歌 讀懂一個故事

    在今天下午的小米Civi 2新品發布會上,小米還帶來了一款新的降噪藍牙耳機Necklace,我們也在發布結束的第一時間給大家帶來這款耳機的簡單分享。現在大家能見到最多的藍牙耳機
  • 十個可以手動編寫的 JavaScript 數組 API

    JavaScript 中有很多API,使用得當,會很方便,省力不少。 你知道它的原理嗎? 今天這篇文章,我們將對它們進行一次小總結。現在開始吧。1.forEach()forEach()用于遍歷數組接收一參
  • 2023 年的 Node.js 生態系統

    隨著技術的不斷演進和創新,Node.js 在 2023 年達到了一個新的高度。Node.js 擁有一個龐大的生態系統,可以幫助開發人員更快地實現復雜的應用。本文就來看看 Node.js 最新的生
  • Temu起訴SHEIN,跨境電商戰事升級

    來源 | 伯虎財經(bohuFN)作者 | 陳平安日前據外媒報道,拼多多旗下跨境電商平臺Temu正對競爭對手SHEIN提起新訴訟,訴狀稱Shein&ldquo;利用市場支配力量強迫服裝廠商與之簽訂獨家
  • 東方甄選單飛:有些鳥注定是關不住的

    作者:彭寬鴻來源:華爾街科技眼&zwj;&zwj;&zwj;&zwj;&zwj;&zwj;&zwj;&zwj;&zwj;&zwj;東方甄選創始人俞敏洪帶隊的&ldquo;7天甘肅行&rdquo;直播活動已在近日順利收官。成立后一
  • 聯想的ThinkBook Plus下一版曝光,鍵盤旁邊塞個平板

    ThinkBook Plus 是聯想的一個特殊筆記本類別,它在封面放入了一塊墨水屏,也給人留下了較為深刻的印象。據有人爆料,聯想的下一款 ThinkBook Plus 可能更特殊,它
  • 英特爾Xe HPG游戲顯卡:擁有512EU,單風扇版本

    據10 月 30 日外媒 TheVerge 消息報道,英特爾 Xe HPG Arc Alchemist 的正面實被曝光,不僅擁有 512 EU 版顯卡,還擁有 128EU 的單風扇版本。另外,這款顯卡 PCB
  • 電博會與軟博會實現"線下+云端"的雙線融合

    在本次“電博會”與“軟博會”雙展會利好條件的加持下,既可以發揮展會拉動人流、信息流、資金流實現快速交互流動的作用,繼而推動區域經濟良性發展;又可以聚
Top 日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不
国产精品久久久久久久久久免费看| 日韩亚洲欧美一区二区三区| 国产精品视频免费观看www| 欧美日韩一区三区四区| 欧美三级网页| 国产日韩欧美在线观看| 1024成人| 亚洲伊人久久综合| 久久久国产精品一区| 欧美成人自拍视频| 欧美亚洲成人免费| 国产综合网站| 99视频一区二区三区| 亚洲欧美日韩精品久久| 久色成人在线| 国产精品国产三级国产专播品爱网 | 久久久噜噜噜久久人人看| 欧美国产精品中文字幕| 国产精品国产成人国产三级| 极品少妇一区二区三区精品视频| 亚洲精品中文字| 性一交一乱一区二区洋洋av| 欧美激情四色 | 亚洲美女少妇无套啪啪呻吟| 午夜在线成人av| 欧美高清视频在线观看| 国产欧美精品日韩区二区麻豆天美| 亚洲国产高清自拍| 午夜宅男久久久| 欧美激情视频一区二区三区在线播放| 国产伦精品一区| 亚洲精品综合| 久久天天躁夜夜躁狠狠躁2022| 欧美日韩欧美一区二区| 亚洲成人在线免费| 欧美亚洲综合在线| 欧美三级电影一区| 最新亚洲一区| 久久久国产视频91| 欧美日韩在线播放三区四区| 在线视频观看日韩| 亚洲欧美制服中文字幕| 欧美片在线观看| 亚洲高清激情| 久久精品亚洲一区二区| 国产精品一区二区欧美| 国产精品99久久久久久久女警| 蜜桃av噜噜一区| 国产婷婷色一区二区三区四区 | 午夜精品一区二区三区在线播放| 欧美精品国产精品日韩精品| 精品不卡视频| 欧美日韩一级黄| 亚洲国产精品成人综合色在线婷婷| 欧美一级久久久| 国产精品a久久久久久| 亚洲国内精品在线| 久久夜色精品亚洲噜噜国产mv| 国产精品视频999| 一二美女精品欧洲| 欧美国产日韩一区二区| 亚洲电影免费在线| 久久人人爽人人爽| 国模私拍一区二区三区| 性欧美精品高清| 国产精品免费福利| 亚洲一区二区三区国产| 欧美日韩情趣电影| 99国产精品久久久久久久久久| 欧美成人精品影院| 亚洲国产日韩欧美| 欧美aⅴ99久久黑人专区| 一区二区视频在线观看| 久久久久九九九九| 国内一区二区三区| 久久精品一区二区三区不卡牛牛 | 免费成人黄色片| 国产专区欧美精品| 久久精品二区三区| 国产综合18久久久久久| 久久国产欧美日韩精品| 国产一区二区| 久久精品毛片| 精品成人免费| 毛片基地黄久久久久久天堂 | 午夜精彩视频在线观看不卡| 国产精品嫩草99a| 亚洲欧美欧美一区二区三区| 国产精品乱码| 性欧美精品高清| 国精品一区二区| 老司机午夜免费精品视频| 亚洲第一中文字幕| 欧美激情精品久久久六区热门| 亚洲精品一区二| 欧美日韩国产小视频| 亚洲网站在线播放| 国产日韩在线视频| 久久精品一区二区国产| 樱花yy私人影院亚洲| 欧美成年人视频网站| 999亚洲国产精| 国产精品高潮视频| 欧美亚洲日本网站| 激情综合在线| 欧美韩国日本一区| 国产精品99久久99久久久二8| 国产精品外国| 久久久噜噜噜久噜久久 | 久久精品日产第一区二区| 精品成人在线视频| 欧美成人影音| 制服丝袜激情欧洲亚洲| 国产日韩成人精品| 久久一区二区视频| 日韩图片一区| 国产精品区一区二区三区| 久久精品中文| 亚洲日本欧美天堂| 国产精品久久久一本精品| 久久精品国产999大香线蕉| 亚洲激情综合| 亚洲欧美日韩国产中文| 国产精品入口福利| 久久婷婷国产综合国色天香 | 麻豆9191精品国产| 一本一本大道香蕉久在线精品| 国产精品一区二区黑丝| 久久人体大胆视频| 一本高清dvd不卡在线观看| 国产精品入口日韩视频大尺度| 久久久999精品视频| 亚洲美女啪啪| 国产视频精品va久久久久久| 欧美va亚洲va国产综合| 亚洲午夜伦理| 在线日韩欧美视频| 国产精品毛片在线| 久久综合伊人| 亚洲自拍偷拍一区| 亚洲黄色免费电影| 国产精品一区二区三区免费观看 | 一本一道久久综合狠狠老精东影业 | 久久亚洲精品一区二区| 日韩午夜av| 国产小视频国产精品| 欧美黄污视频| 久久精品亚洲一区二区| 中文亚洲视频在线| 在线免费观看一区二区三区| 国产精品国产三级国产普通话三级| 久久免费视频在线| 亚洲自拍啪啪| 亚洲精品一区二区三区福利| 国产一区二区三区的电影| 欧美日韩成人在线| 久久久国产91| 亚洲影院免费观看| 亚洲精品国产精品国自产在线| 国产亚洲aⅴaaaaaa毛片| 欧美日韩国产黄| 久久综合一区二区三区| 欧美一区在线直播| 亚洲一区国产一区| 亚洲精品婷婷| 在线看欧美视频| 国产热re99久久6国产精品| 欧美日韩精品不卡| 免费观看亚洲视频大全| 欧美一级片在线播放| 一区二区三区四区蜜桃| 亚洲高清资源综合久久精品| 国产午夜精品一区理论片飘花 | 久久久www| 羞羞色国产精品| 一区二区三区av| 亚洲国产综合在线| 在线观看欧美| 国产综合第一页| 国产精品视频成人| 欧美图区在线视频| 欧美人成免费网站| 欧美高清视频一区二区三区在线观看| 久久av一区二区三区| 亚洲欧美综合精品久久成人| 正在播放欧美视频| 欧美日韩激情网| 欧美国产日韩二区| 欧美1区3d| 欧美成黄导航| 蜜桃av一区二区三区| 久久字幕精品一区| 久久一二三区| 久久综合一区二区| 久久亚洲精选| 久久亚洲综合色一区二区三区| 久久精品国产清自在天天线| 欧美亚洲午夜视频在线观看| 午夜精品一区二区三区在线视 | 99在线精品视频| 亚洲毛片视频| 一本色道久久综合亚洲精品婷婷| 亚洲另类自拍| 9久re热视频在线精品|