探索Redis 6.0的新特性

55fcd04c2a094ab8b405233acf0af7e5.png

Redis(Remote Dictionary Server)是一個開源的內存中數據結構存儲系統,通常被用作緩存、消息隊列和實時數據處理等場景。它的簡單性、高性能以及豐富的數據結構支持使其成為了眾多開發者和企業的首選。在Redis 6.0版本中,引入了一系列令人期待的新特性和改進,本文將深入探討這些新特性,以便開發者更好地理解和利用Redis在其項目中的潛力。

1.新特性

  • 深度嵌套的從復制:在Redis 6.0中,引入了深度嵌套的從復制,使得從節點可以成為其他主節點的從節點,從而構建多級的從節點拓撲結構。這一特性提高了系統的可擴展性和靈活性,使得數據在分布式環境中更加可靠。
  • 線程模型改進:Redis 6.0對線程模型進行了改進,引入了新的I/O線程,使得Redis能夠更好地利用多核處理器的性能。這一改進提高了Redis在高負載環境下的性能表現,并降低了對單個CPU核心的依賴。
  • 新的RDB版本:Redis 6.0引入了新的RDB版本(RDB版本 9),在處理大型數據庫時具有更好的性能和可靠性。這一改進使得Redis在備份和恢復大規模數據時更加高效,降低了與持久化相關的性能開銷。
  • 慢查詢日志改進:Redis 6.0對慢查詢日志進行了改進,引入了新的命令SLOWLOG GET,使得開發者能夠更加靈活地檢索和分析慢查詢日志。這一改進有助于開發者更好地識別和優化性能瓶頸,提高系統的響應速度。
  • TLS支持: Redis 6.0新增了對TLS(Transport Layer Security)的支持,通過加密保護數據在傳輸過程中的安全性。這一改進使得Redis在安全性方面更加強大,并能夠滿足更嚴格的安全要求。

2. 多線程模型

1. redis 6.0 提供了多線程的支持,redis 6 以前的版本,嚴格來說也是多線程,只不過執行用戶命令的請求時單線程模型,還有一些線程用來執行后臺任務, 比如 unlink 刪除 大key,rdb持久化等。

redis 6.0 提供了多線程的讀寫IO, 但是最終執行用戶命令的線程依然是單線程的,這樣,就沒有多線程數據的競爭關系,依然很高效。

redis 6.0 以前線程執行模式,如下操作在一個線程中執行完成

?

078c47c35fbdffe1824ebbf561a60083.png

redis 6.0 線程執行模式:

可以通過如下參數配置多線程模型:

如:

io-threads 4 // 這里說 有三個IO 線程,還有一個線程是main線程,main線程負責IO讀寫和命令執行操作

默認情況下,如上配置,有三個IO線程, 這三個IO線程只會執行 IO中的write 操作,也就是說,read 和 命令執行 都由main線程執行。最后多線程將數據寫回到客戶端。

?

6992dcf3b244196428fda25fb27f48ed.png

開啟了如下參數:

io-threads-do-reads yes // 將支持IO線程執行 讀寫任務。

?

a379521edab2864b0e1a7082613860df.png

3. client side caching

客戶端緩存:redis 6 提供了服務端追蹤key的變化,客戶端緩存數據的特性,這需要客戶端實現

?

8544d5fc5b42fa1905407188b13c3b32.png

執行流程為, 當客戶端訪問某個key時,服務端將記錄key 和 client ,客戶端拿到數據后,進行客戶端緩存,這時,當key再次被訪問時,key將被直接返回,避免了與redis 服務器的再次交互,節省服務端資源,當數據被其他請求修改時,服務端將主動通知客戶端失效的key,客戶端進行本地失效,下次請求時,重新獲取最新數據。

目前只有lettuce對其進行了支持:

<dependency><groupId>io.lettuce</groupId><artifactId>lettuce-core</artifactId><version>6.0.0.RELEASE</version>
</dependency>
public static void main(String[] args) throws InterruptedException {RedisClient redisClient = RedisClient.create("redis://192.168.109.200");Map<String, String> clientCache = new ConcurrentHashMap<>();StatefulRedisConnection<String, String> myself = redisClient.connect();CacheFrontend<String, String> frontend =ClientSideCaching.enable(CacheAccessor.forMap(clientCache),myself,TrackingArgs.Builder.enabled().noloop());String key="csk";int count = 0;while (true){System.out.println(frontend.get(key));TimeUnit.SECONDS.sleep(3);if (count++ == Integer.MAX_VALUE){myself.close();redisClient.shutdown();}}
}

4.Acls訪問權限控制

ACL 是對于命令的訪問和執行權限的控制,默認情況下,可以有執行任意的指令,兼容以前版本

ACL設置有兩種方式:

1. 命令方式

ACL SETUSER + 具體的權限規則, 通過 ACL SAVE 進行持久化

2. 對 ACL 配置文件進行編寫,并且執行 ACL LOAD 進行加載

ACL存儲有兩種方式,但是兩種方式不能同時配置,否則直接報錯退出進程

1.redis 配置文件: redis.conf

2.ACL配置文件, 在redis.conf 中通過 aclfile /path 配置acl文件的路徑

命令方式:

ACL SETUSER alice   // 創建一個 用戶名為 alice的用戶

用如上的命令創建的用戶語義為:

  1. 處于 off 狀態, 它是被禁用的,不能用auth進行認證
  2. 不能訪問任何命令
  3. 不能訪問任意的key
  4. 沒有密碼

如上用戶alice 沒有任何意義。

創建一個對 cached: 前綴具有get命令執行權限的用戶,并且設置密碼:

acl setuser alice on >pass123  ~cached:* +get 
auth alice pass123
set a a
(error) NOPERM this user has no permissions to run the 'set' command or its subcommand
get a a 
(error) NOPERM this user has no permissions to access one of the keys used as arguments
get cached:name
vvv

如上,如果訪問沒有被授權的命令,或者key, 將報錯,set 命令沒有被授權, key a 沒有被授權,

cached:name 可以通過驗證。

更符合閱讀習慣的格式

ACL GETUSER alice

添加多個訪問模式,空格分隔, 注意,切換其他用戶進行登錄,alice沒有admin權限

ACL SETUSER alice ~objects:* ~items:* ~public:*

針對類型命令的約束

ACL SETUSER alice on +@all -@dangerous >密碼 ~*

這里+@all: 包含所有得命令 然后用-@ 去除在redis command table 中定義的 dangerous 命令

?

104ae27177a464fbab934a82315a0c88.png

可以通過如下命令進行查看具體有哪些命令屬于某個類別

acl cat // 查看所有類別
acl cat dangerous // 查看所有的 dangerous 命令

開放子命令

ACL SETUSER myuser -client +client|setname +client|getname

禁用client 命令,但是開放 client 命令中的子命令 setname 和 getname ,只能是先禁用,后追加子命令,因為后續可能會有新的命令增加。

5. 總結

以下是使用表格對比Redis 6.0與舊版本的主要特性和改進:

特性/改進Redis 6.0舊版本
深度嵌套的從復制支持深度嵌套的從復制,構建多級從節點拓撲結構僅支持單級從節點拓撲結構
線程模型改進引入新的I/O線程,更好地利用多核處理器性能線程模型相對簡單,性能受限
新的RDB版本引入RDB版本 9,處理大型數據庫性能更優舊版本存在性能瓶頸,處理大規模數據效率低
慢查詢日志改進引入新的命令SLOWLOG GET,更靈活地檢索和分析慢查詢日志慢查詢日志功能相對簡單,缺乏靈活性
TLS支持新增對TLS的支持,保護數據在傳輸過程中的安全性缺乏對傳輸層安全性的支持

?


更多文章

Redis為何如此快速?-CSDN博客

Redis持久化、主從與哨兵架構詳解-CSDN博客

Redis集群選舉流程詳解-CSDN博客

ZAB 協議解析:ZooKeeper分布式一致性的核心-CSDN博客

MySQL8:開啟數據庫管理的新時代-CSDN博客

?

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/710630.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/710630.shtml
英文地址,請注明出處:http://en.pswp.cn/news/710630.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Vue3報錯Promise executor functions should not be async.

解決方法 加注釋。。。// eslint-disable-next-line no-async-promise-executor // eslint-disable-next-line no-async-promise-executor new Promise<boolean>(async (resolve, reject) > {... }),

Ubuntu綁定USB接口到固定端口

綁定端口 打開終端&#xff0c;輸入以下命令查看USB端口信息&#xff1a; udevadm info -a -n /dev/ttyUSB0執行后&#xff0c;可以看到部分輸出如下: 找到第一個&#xff0c;a-b:c格式的KERNELS&#xff0c;記住這個值&#xff0c;后面會用到。 linlin-B660M-D2H-DDR4:~$ u…

【深藍學院】移動機器人運動規劃--第7章 集群機器人運動規劃--筆記

文章目錄 0. Contents1. Multi-Agent Path Finding (MAPF)1.1 HCA*1.2 Single-Agent A*1.3 ID1.4 M*1.5 Conflict-Based Search(CBS)1.6 ECBS1.6.1 heuristics1.6.2 Focal Search 2. Velocity Obstacle (VO&#xff0c;速度障礙物)2.1 VO2.2. RVO2.3 ORCA 3. Flocking model&am…

【每日前端面經】2023-02-29

題目來源: 牛客 如何理解前端這個崗位 簡單地說就是設計師做好網頁效果圖&#xff0c;前端將效果圖轉化成頁面&#xff0c;之后交給后端程序員&#xff0c;中間的這段工作就是前端 瀏覽器如何渲染HTML 將載入的HTML文件解析成DOM樹&#xff0c;并且將各個標記標識解析成DOM…

SQL的窗口函數

SQL的窗口函數 文章目錄 SQL的窗口函數1. 介紹2. 聚合函數0.數據準備1. AVG2. COUNT3. MAX4. MIN5. 標準差6. SUM 3. 排序函數1. CUME_DIST2. RANK, DENSE_RANK, ROW_NUMBER3. PERCENT_RANK4. NTILE 4. 值函數(偏移函數)1. FIRST_VALUE2. LAST_VALUE3. LAG4. LEAD5. NTH_VALUE …

ChatGPT4.0 的優勢、升級 4.0 為什么這么難以及如何進行升級?

前言 “ChatGPT4.0一個月多少人民幣&#xff1f;” ”chatgpt4賬號“ ”chatgpt4 價格“ “chatgpt4多少錢” 最近發現很多小伙伴很想知道關于ChatGPT4.0的事情&#xff0c;于是寫了這篇帖子&#xff0c;幫大家分析一下。 一、ChatGPT4.0 的優勢 &#xff08;PS&#xff1a;…

LINUX基礎培訓二十七之shell標準輸入、輸出、錯誤

一、Shell 輸入/輸出重定向 大多數 UNIX 系統命令從你的終端接受輸入并將所產生的輸出發送回??到您的終端。一個命令通常從一個叫標準輸入的地方讀取輸入&#xff0c;默認情況下&#xff0c;這恰好是你的終端。同樣&#xff0c;一個命令通常將其輸出寫入到標準輸出&#xff…

【樹莓派系統配置+python3.8+環境配置踩坑點匯總】raspberrypi

最近又開始搞樹莓派的深度學習模型。很多windows端的環境需要在樹莓派上重新部署&#xff0c;中間出現了非常多的問題。主要以各種庫的下載安裝為主要。 首先&#xff0c;第一個問題&#xff1a; 樹莓派系統燒錄之后&#xff0c;默認apt一般需要升級看&#xff0c;而默認下載…

無窮級數法求Π

任務描述 本關任務&#xff1a;編寫一個無窮級數法計算圓周率的小程序。 相關知識 為了完成本關任務&#xff0c;你需要掌握&#xff1a; 無窮級數法 無窮級數法 π 是個超越數&#xff0c;圓周率的超越性否定了化圓為方這種尺規作圖精確求解問題的可能性。有趣的是&…

【Spring】18 Bean 定義繼承

文章目錄 介紹聲明式配置抽象Bean定義繼承的配置項注意&#xff1a;抽象Bean預實例化結論 Spring 框架提供了一個強大的功能&#xff0c;稱為 Bean 定義繼承&#xff0c; 允許開發人員高效地在 bean 之間重用和自定義配置。在本篇文章中我們將介紹 Bean 定義繼承的概念&#x…

JVM性能優化

運行時優化 方法內聯 方法內聯&#xff0c;是指 JVM在運行時將調用次數達到一定閾值的方法調用替換為方法體本身 &#xff0c;從而消除調用成本&#xff0c;并為接下來進一步的代碼性能優化提供基礎&#xff0c;是JVM的一個重要優化手段之一。 注&#xff1a; C的inline屬于編…

babylonsjs入門-基礎模版

基于babylonjs封裝的一些功能和插件 &#xff0c;希望有更多的小伙伴一起玩babylonjs&#xff1b; 歡迎加群&#xff08;點擊群號傳送&#xff09;&#xff1a;464146715 官方文檔 中文文檔 案例傳送門 ? 懶得打字&#xff0c;你們直接去copy組件吧&#xff0c;主要看這2…

舊版android模擬器,37歲程序員被裁

前言 從18年畢業至今&#xff0c;就職過兩家公司&#xff0c;大大小小項目做了幾個&#xff0c;非常感謝我的兩位老大&#xff0c;在我的android成長路上給予我很多指導&#xff0c;亦師亦友的關系。 從年前至今參加面試了很多公司&#xff0c;也收到了幾家巨頭的offer&#…

transformer--編碼器2(前饋全連接層、規范化層、子層鏈接結構、編碼器層、編碼器)

前饋全連接層 什么是前饋全連接層: 在Transformer中前饋全連接層就是具有兩層線性層的全連接網絡 前饋全連接層的作用: 考慮注意力機制可能對復雜過程的擬合程度不夠,通過增加兩層網絡來增強模型的能力 code # 前饋全連接層 class PositionwiseFeedForward(nn.Module):de…

絕地求生:發現吃雞號被盜,怎么操作才是最正確的

首先閑游盒先了解一下盜號者的盜號流程 一般盜號的流程是先把你steam上的皮膚飾品出售&#xff0c;然后把余額轉走&#xff0c;再把steam賬號作為黑號進行出售。 所以當閑游盒發現號被盜的時候也分為兩種情況&#xff1a;一種是他正在出售商品的時候&#xff0c;你收到郵箱提示…

Linux命令行與shell腳本編程大全-3-4

第三部分高級shell腳本編程 第17章創建函數 17.1 腳本函數基礎 17.1.1 創建函數 在bash shell 腳本中創建函數的語法有兩種。第一種語法是使用關鍵字function&#xff0c;隨后跟 上分配給該代碼塊的函數名&#xff1a; function name { commands } 17.1.2 使用函數 要在腳…

代碼隨想錄算法訓練營Day46 | 139.單詞拆分、多重背包(卡碼網56.攜帶礦石資源)

139.單詞拆分 可以理解為一道 完全背包 排列 的題&#xff0c;dp數組定義和遞推公式部分腦子需要轉個彎 1、DP數組定義&#xff1a;一維滾動數組vector<bool>。dp[j]表示字符串s的[0, j]子串是否能夠匹配。 2、DP數組初始化&#xff1a;dp[0]初始化為true&#xff0c;其…

Multi-Head Attention詳解

文中大部分內容以及圖片來自&#xff1a;https://medium.com/hunter-j-phillips/multi-head-attention-7924371d477a 當使用 multi-head attention 時&#xff0c;通常d_key d_value &#xff08;d_model / n_heads&#xff09;&#xff0c;其中n_heads是頭的數量。研究人員稱…

01-Vue2 介紹與指令的使用

1. Vue核心 1.1. Vue簡介 1.1.1. 官網 中文官網Vue.js - 漸進式 JavaScript 框架 | Vue.js (vuejs.org)https://cn.vuejs.org/ 英文官網Vue.js - The Progressive JavaScript Framework | Vue.js (vuejs.org)https://vuejs.org/ 1.1.2. 介紹與描述 VUE是構建于用戶界面的漸進…

靶機滲透之sar

Name: Sar: 1Date release: 15 Feb 2020Author: LoveSeries: Sar Download: https://drive.google.com/open?id1AFAmM21AwiAEiVFUA0cSr_GeAYaxd3lQ 對于vulnhub中的靶機&#xff0c;我們都需先下載鏡像&#xff0c;然后導入VM&#xff0c;并將網絡連接改為NAT模式。首先我們…