Redis面試 實戰貼 后面持續更新鏈接

redis是使用C語言寫的。

面試問題列表:
Redis支持哪些數據類型?各適用于什么場景?

Redis為什么采用單線程模型?優勢與瓶頸是什么?

RDB和AOF持久化的區別?如何選擇?混合持久化如何實現?

Redis緩存穿透、雪崩、擊穿的解決方案?

如何用Redis實現分布式鎖?RedLock算法的核心思想?Redisson的看門狗機制原理?

Redis內存淘汰策略有哪些?

Redis的Pipeline和Lua腳本適用場景是什么?使用時需要注意什么?

Redis的過期鍵刪除策略?

如何利用Redis實現延遲隊列?

Redis的發布訂閱模型有哪些缺點?

Redis集群主從復制的流程是怎樣的?

Redis Sentinel如何實現高可用?

什么是腦裂問題?如何避免?

Redis Cluster的數據分片原理?為什么Redis Cluster不支持跨節點事務?Redis Cluster模式下如何實現跨節點事務?

集群如何擴容?數據遷移過程?

集群模式下,批量操作(如MSET)需要注意什么?

Codis與Redis Cluster的優缺點對比?Redis Cluster節點間通信協議?

Redis集群的Slot分配機制是什么?如何解決數據傾斜?

Redis的Hot Key自動發現與處理方案?

Redis大Key(Big Key)的優化策略?

Redis內存碎片率高的原因及解決方案?

Redis 6.0多線程模型如何工作?

如何設計一個二級緩存(Redis+Caffeine)架構?

Redis架構圖

# Redis五大架構模式詳解(圖示+場景)## 1. 單機模式
```asciidoc
+-----------------+
| Redis單機實例    |
| (全量數據存儲)    |
+-----------------+

特點
? 部署簡單
? 數據全內存操作
? 無高可用保障
? 容量受單機限制

適用場景:開發測試環境


2. 主從復制架構

       +----------+        寫請求| Master   | <───────┐+----------+         ││               │▼ 數據同步       │
+----------+  +----------+   │
| Slave1   |  | Slave2   | ←─┘ 讀請求
+----------+  +----------+

核心機制
🔹 異步數據復制
🔹 讀寫分離(寫Master→讀Slave)
🔹 從節點可水平擴展

適用場景:讀多寫少業務


3. 哨兵模式(Sentinel)

        +--------------+| Sentinel集群 |+------+-------+│監控
+--------------+--------------+
| Master節點                  |
+--------------+--------------+│ 故障轉移
+--------------+--------------+
| 新Master節點(原Slave提升)  |
+-----------------------------+

核心能力
🚨 自動故障檢測與轉移
📊 集群狀態實時監控
🔀 客戶端自動發現新Master

適用場景:需要高可用保障的生產系統


4. Cluster集群模式

+--------+    +--------+    +--------+
| 分片1   | ←→ | 分片2   | ←→ | 分片3   |
| (16384槽)|    | (16384槽)|    | (16384槽)|
+---+-----+    +---+-----+    +---+-----+│              │              │▼              ▼              ▼
+---+-----+    +---+-----+    +---+-----+
| 副本節點 |    | 副本節點 |    | 副本節點 |
+--------+    +--------+    +--------+

核心特性
🔧 數據自動分片(hash slot)
🌐 節點間Gossip協議通信
? 支持水平擴展

適用場景:大數據量、高并發場景


5. 代理模式(Codis/Twemproxy)

+-----------------+
| 代理層           |
| (路由/負載均衡)   |
+-----+-----+-----+|     |     |
+-----+ +-----+ +-----+
| Redis組1 | Redis組2 | Redis組3
+---------+ +---------+ +---------+

優勢
🛡? 客戶端無感知擴容
📡 支持多語言客戶端
🔀 靈活的路由策略

適用場景:已有Redis集群的平滑遷移


架構選型指南

場景需求推薦架構
開發/測試單機模式
讀多寫少主從復制
7*24高可用哨兵模式
大數據量存儲Cluster集群
舊集群遷移代理模式

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

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

相關文章

Selenium自動化測試工具常見函數

目錄 前言 一、什么是自動化&#xff1f; 二、元素的定位 三、測試對象的操作 3.1輸入文本send_keys() 3.2按鈕點擊click() 3.3清除文本clear() 3.4獲取文本信息text 3.5獲取頁面的title與URL 四、窗口 4.1窗口的切換switch_to.window() 4.2窗口大小設置 …

seata 1.5.2 升級到2.1.0版本

一、部署1.5.2 1、解壓縮 tar -xvf apache-seata-***-incubating-bin.tar.gz 2、修改conf下的application.yml 只需要修改seata下的此配置&#xff0c;然后再nacos中添加其它配置&#xff0c;下面是application.yml的配置&#xff1a; server:port: 7091spring:applic…

Vue知識框架

一、Vue 基礎核心 1. 響應式原理 數據驅動&#xff1a;通過 data 定義響應式數據&#xff0c;視圖自動同步數據變化。 2、核心機制 Object.defineProperty&#xff08;Vue 2.x&#xff09;或 Proxy&#xff08;Vue 3.x&#xff09;實現數據劫持。依賴收集&#xff1a;追蹤…

Nginx靜態資源增加權限驗證

Nginx靜態資源增加權限驗證 一、前言二、解決思路2.1、方式一2.2、方式二三、代碼3.1、方式一3.1.1、前端代碼3.1.2、后端代碼3.1.3、Nginx調整3.1.4、注意事項3.2.方式二四、參考資料一、前言 在項目開發的過程中,項目初期,及大部分小型項目都是使用共享磁盤進行靜態文件的…

分析NVIDIA的股價和業績暴漲的原因

NVIDIA自2016年以來股價與業績的持續高增長&#xff0c;是多重因素共同作用的結果。作為芯片行業的領軍企業&#xff0c;NVIDIA抓住了技術、戰略、市場與行業趨勢的機遇。以下從技術創新、戰略布局、市場需求、財務表現及外部環境等維度&#xff0c;深入分析其成功原因&#xf…

更換芯片后因匝數比變化,在長距離傳輸時出現通訊問題。我將從匝數比對信號傳輸的影響、阻抗匹配等方面分析可能原因,并給出相應解決方案。

匝數比影響信號幅度與相位&#xff1a;原 HM1188 芯片匝數比 1:1&#xff0c;信號在變壓器原副邊傳輸時幅度基本不變&#xff1b;更換為 XT1188 芯片&#xff08;匝數比 1:2&#xff09;后&#xff0c;根據變壓器原理&#xff0c;副邊輸出信號幅度會變為原邊的 2 倍。短距離 10…

Python引領前后端創新變革,重塑數字世界架構

引言:Python 在前后端開發的嶄新時代 在當今數字化時代,軟件開發領域持續創新,而 Python 作為一門功能強大、應用廣泛的編程語言,正引領著前后端開發的變革浪潮。Python 以其簡潔易讀的語法、豐富的庫和框架生態系統,以及強大的跨領域適用性,在計算機領域占據了舉足輕重…

IP SSL證書常見問題助您快速實現HTTPS加密

一、什么是IP SSL證書&#xff1f; IP SSL證書是一種專門用于保護基于IP地址的網站或服務器的SSL證書。與傳統的域名SSL證書不同&#xff0c;它不需要綁定域名&#xff0c;而是直接與公網IP地址關聯。當用戶訪問該IP地址時&#xff0c;瀏覽器與服務器之間會建立加密連接&#…

「Mac暢玩AIGC與多模態27」開發篇23 - 多任務摘要合成與提醒工作流示例

一、概述 本篇基于興趣建議輸出的方式&#xff0c;擴展為支持多任務輸入場景&#xff0c;介紹如何使用 LLM 對用戶輸入的多項待辦事項進行摘要整合、生成重點提醒&#xff0c;并保持自然語言風格輸出&#xff0c;適用于任務總結、進度引導、日程提醒等輕量型任務生成場景。 二…

前端自學入門:HTML 基礎詳解與學習路線指引

在互聯網的浪潮中&#xff0c;前端開發如同構建數字世界的基石&#xff0c;而 HTML 則是前端開發的 “入場券”。對于許多渴望踏入前端領域的初學者而言&#xff0c;HTML 入門是首要挑戰。本指南將以清晰易懂的方式&#xff0c;帶大家深入了解 HTML 基礎&#xff0c;并梳理前端…

js 兩個數組中的指定參數(id)相同,為某個對象設置disabled屬性

在JavaScript中&#xff0c;如果想要比較兩個數組并根據它們的id屬性來設置某個對象的disabled屬性為true&#xff0c;你可以使用幾種不同的方法。這里我將介紹幾種常用的方法&#xff1a; 方法1&#xff1a;使用循環和條件判斷 const array1 [{ id: 1, name: Item 1 },{ id…

編寫大模型Prompt提示詞方法

明確目標和任務 // 調用LLM進行分析const prompt 你是一名嚴格而友好的英語口語評分官&#xff0c;專業背景包括語音學&#xff08;phonetics&#xff09;、二語習得&#xff08;SLA&#xff09;和自動語音識別&#xff08;ASR&#xff09;。你的任務是&#xff1a; ① 比對參…

MCP系列(一)什么是MCP?

MCP 是什么&#xff1a;從 USB-C 到 AI 的「萬能接口」哲學 MCP&#xff08;Model Context Protocol&#xff0c;模型上下文協議&#xff09; 是Anthropic于2024年11月推出的AI跨系統交互標準&#xff0c;專為解決LLM&#xff08;大語言模型&#xff09;的「數字失語癥」——讓…

NoMachine 將虛擬顯示器改為物理顯示器

一、前言 大多數服務器需求是設置為虛擬顯示器&#xff0c;因為服務器本身不接物理的顯示器。但我的需求不太一樣&#xff0c;服務器就在身邊&#xff0c;有時候關閉遠控也需要實時監測&#xff0c;所以接了物理的顯示器。 NoMachine 默認會為用戶創建一個新的桌面會話&#xf…

YOLOv8 優化:基于 Damo-YOLO 與 DyHead 檢測頭融合的創新研究

文章目錄 YOLOv8 的背景與發展Damo-YOLO 的優勢與特點DyHead 檢測頭的創新之處融合 Damo-YOLO 與 DyHead 檢測頭的思路融合后的模型架構融合模型的代碼實現導入必要的庫定義 Damo-YOLO 的主干網絡定義特征金字塔網絡&#xff08;FPN&#xff09;定義 DyHead 檢測頭定義融合后的…

關稅沖擊下,FBA國際物流企業如何靠智能拓客跑出增長“加速度”?

國際物流行業正迎來前所未有的增長機遇。據中研普華最新報告&#xff0c;2025年全球物流市場規模已突破6.27萬億美元&#xff0c;其中中國跨境物流市場預計達2.71萬億元。在全球化與數字化雙輪驅動下&#xff0c;國際物流從“規模擴張”邁向“價值重構”。可以說&#xff0c;國…

《內存單位:解鎖數字世界的“度量衡”》

&#x1f680;個人主頁&#xff1a;BabyZZの秘密日記 &#x1f4d6;收入專欄&#xff1a;C語言 &#x1f30d;文章目入 一、基礎單位&#xff1a;字節&#xff08;Byte&#xff09;二、進階單位&#xff1a;千字節&#xff08;KB&#xff09;、兆字節&#xff08;MB&#xff09…

PyQt 探索QMainWindow:打造專業的PyQt5主窗

在PyQt5的世界里&#xff0c;窗口的創建和管理是構建圖形用戶界面&#xff08;GUI&#xff09;的基礎。QMainWindow作為主窗口類&#xff0c;為開發者提供了強大而靈活的應用程序框架。今天&#xff0c;就讓我們一起深入了解QMainWindow的奧秘。 QMainWindow簡介 QMainWindow…

Missashe高數強化學習筆記(隨時更新)

Missashe高數強化學習筆記 說明&#xff1a;這篇筆記用于博主對高數強化課所學進行記錄和總結。由于部分內容寫在博主的日記博客里&#xff0c;所以博主會不定期將其重新copy到本篇筆記里。 第一章 函數極限連續 第二章 一元函數微分學 第三章 一元函數積分學 第一節 不定…

Ruby 字符串(String)

Ruby 字符串&#xff08;String&#xff09; 引言 在編程語言中&#xff0c;字符串是表示文本數據的一種基本數據類型。在Ruby中&#xff0c;字符串處理是日常編程中非常常見的一項任務。本文將詳細介紹Ruby中的字符串&#xff08;String&#xff09;類型&#xff0c;包括其創…