keycloak~分散式緩存的使用

来源:https://www.cnblogs.com/lori/archive/2023/11/21/17847379.html
-Advertisement-
Play Games

keycloak目前提供了幾種分散式緩存,我們自己的緩存,如果希望是分散式的,可以將緩存添加到以下幾個緩存里即可 actionTokens clientSessions loginFailures offlineClientSessions offlineSessions sessions work ...


keycloak目前提供了幾種分散式緩存,我們自己的緩存,如果希望是分散式的,可以將緩存添加到以下幾個緩存里即可

  • actionTokens
  • clientSessions
  • loginFailures
  • offlineClientSessions
  • offlineSessions
  • sessions
  • work

如果你希望自己開發分散式緩存,還是需要複雜的,需要配置,檢查,獲取遠程分散式緩存的代碼,比較複雜,有興趣的同學,可以查看keycloak源代碼,關於keycloak-model-infinispan項目的實現。

直接使用現有分散式緩存

下麵代碼,將在現有的work緩存里,添加自己的緩存hello,尾碼是用戶ID,生命周期是access_token的有效期秒數

// 獲取 Infinispan 連接提供程式和緩存領域提供程式
InfinispanConnectionProvider connectionProvider =
  keycloakSession.getProvider(InfinispanConnectionProvider.class);
String key = "hello_" + userId;
if (connectionProvider.getCache("work") != null) {
int life=keycloakSession.getContext().getRealm().getAccessTokenLifespan();
connectionProvider.getCache("work").put(key, "", life, TimeUnit.SECONDS);
}

緩存模式

Infinispan支持四種緩存模式:本地(Local)模式、複製(Replicated)模式、失效(Invalidation)模式、分散式(Distribution)模式。除本地模式外,其他三種模式均為集群模式緩存。

3.1 本地模式

本地模式下,數據緩存在本地記憶體,節點間數據不共用。Infinispan的cache對象繼承自Java的ConcurrentMap,和直接採用map相比,其優勢在於:

支持緩存數據持久化,支持mongodb、leveldb等多種資料庫。Infinispan通過設置cache store僅將將上述資料庫作為緩存數據的存儲介質,並不涉及資料庫本身的其他高級特性。
支持eviction策略,避免記憶體耗盡。
支持expiration策略,保證長期未被使用的數據被清除。
基於MVCC的併發處理策略,採用CAS和其他lock-free演算法保證高性能。
*事務性保證。

3.2 失效模式

失效模式下,數據需持久化到資料庫(或其他持久化設備)中,節點間並不共用任何數據。當發生數據更新時,更新資料庫並通知其他節點該數據已過期。節點發現數據過期後,採用lazy策略從資料庫更新至緩存。這樣做的好處在於:

  1. 網路負荷最小化。和複製模式下更新數據相比,失效消息要小的多,有效降低了網路負荷。
  2. 延遲更新。節點發現數據失效後,無需立即更新數據,僅當需訪問該數據時才執行更新。
  3. 支持同步、非同步兩種失效方式。
  4. 同步失效:發送失效通知,並等待所有節點響應(收到失效消息,並逐出過期數據)後返回。
  5. 非同步失效:發送失效通知,廣播至所有節點,並直接返回。
  6. 數據存在持久化需求,緩存作為持久數據的中間層。在讀操作頻繁的場景下,採用Infinispan,避免每次直接訪問資料庫,提高讀取性能。

3.3 複製模式

  1. 複製模式是集群模式的一種,在該模式任何一個節點的數據變更將複製到其他所有節點上,這使得集群中任何一個節點都包含了完整的緩存數據。
  2. 和嵌入式模式組合時,所有數據均保存在應用程式本地,讀操作僅需訪問本地記憶體,性能最高。
  3. 和C\S模式組合時,因為數據都保存在遠端,讀寫都需要進行一次遠端訪問,此時複製模式和分散式模式相比並無明顯優勢。
  4. Infinispan設計了同步、非同步兩種方式用於將本節點的數據變更操作通知到其他節點,對於每種操作又支持TCP、UDP兩種通信方式。採用UDP協議時,通過疊加JGroups的NAKACK2和UNICAST3保證傳輸的可靠性,具體可參見[JGroups支持]。

3.4 分散式(Distributed)模式

分佈模式是Infinispan支持的可擴展性最好的一種模式。在這種模式下,用戶可以配置固定數量(numOwners)的副本數,而不需要複製數據到所有的節點上。複製有限個副本既可以控制開銷,也可以帶來數據訪問性能和可靠性的提升。
在集群中,Infinispan通過一致性哈希(Consistent Hashing)演算法來確定數據訪問和存儲的位置。使用一致性哈希是好處是:當現有節點失效或新節點加入時,系統不需要重新計算哈希來重新分配數據在集群中的存儲位置。
和複製模式相比,優勢如下:

可擴展性:對集群節點數量沒有限制,可根據業務需要,靈活的增、刪節點。
數據網格:假設集群中有三個節點A,B,C,記憶體大小為8G,複製模式下集群容量為8G。分散式模式下,如果每個條目保存在2個節點上,集群的容量為(8 G* 3) / 2 = 12G。

和複製模式一樣,分散式模式也支持同步和非同步兩種模式

作者:倉儲大叔,張占嶺,
榮譽:微軟MVP
QQ:853066980

支付寶掃一掃,為大叔打賞!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Doris中,Leader節點與非Leader節點和Observer節點之間的元數據高可用和一致性,是通過bdbje(全稱:Oracle Berkeley DB Java Edition)的一致性和高可用實現的。 元數據與同步流程 元數據主要存儲四類數據: 用戶數據信息. 包括資料庫, 表的sche ...
  • 前言 在自學framework的時候,最大的難題就是如何動手實踐修改framework並且看到實踐效果。但是Android系統是需要linux環境下編譯的,我們一般的個人電腦都是windows系統,所以為了學習framework重裝電腦為linux系統有點不太實際。個人也試過虛擬機,但是系統資源開銷 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 Vue的5種處理Vue異常的方法 相信大家對Vue都不陌生。在使用Vue的時候也會遇到報錯,也會使用瀏覽器的F12 來查看報錯信息。但是你知道Vue是如何進行異常拋出的嗎?vue 是如何處理異常的呢?接下來和大家介紹介紹,Vue是如何處理 ...
  • 可以少去理解一些不必要的概念,而多去思考為什麼會有這樣的東西,它解決了什麼問題,或者它的運行機制是什麼? 一. 環境搭建 工作編輯器:Visual Studio Code。 Javascript 解析器、運行環境 Node.js 的安裝。 npm 安裝:npm 是 Node.js 的軟體包管理器。 ...
  • 博客園美化教程指引[資料自取] 前言 很久沒有打開博客園了,最近打開發現博客園之前發佈的可能有些小問題,不知道大家有沒有,索性全部重新配置了,所以這是一個新的部署指引以及老版本的修複。 老版本修複 修改一下頁腳這一段 替換之前的複製進去即可 footer: { style: 1, text: { l ...
  • 本章以實時OALP引擎Clickhouse(簡稱ck)為例, 以其面向場景, 架構設計, 細節實現等方面來介紹, 深度瞭解其如何成為了OLAP引擎中的性能之王. ...
  • 本文首發於公眾號:Hunter後端 原文鏈接:Django筆記四十二之model使用validator驗證器 這一篇筆記介紹一下 model 里的 validator 驗證器。 首先,這是個什麼東西呢? 在 model 的第四篇筆記里,我們介紹了欄位的一些屬性,比如是否允許為空,varchar 類型 ...
  • Lambda表達式 Lambda是一個匿名函數,我們可以把Lambda表達式理解為是一段可以傳遞的代碼(將代碼像數據一樣進行傳遞)。使用它可以寫出更簡潔、更靈活的代碼。作為一種更緊湊的代碼風格,使Java的語言表達能力得到了提升。 本質: 作為函數式介面的實例, 沒有介面就沒意義了. // 簡單使用 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...