黑馬2022最新redis課程筆記知識點(面試用)持續更新

来源:https://www.cnblogs.com/dengxiaoyi/archive/2022/08/06/16558233.html
-Advertisement-
Play Games

redis入門 redis的常見五種數據類型 String類型 String類型,類似於java中的String類型,常見使用get,set方法。 ==String類型還可以存儲json字元串格式==。 Hash類型 Hash類型,也叫散列,它的value是一個無序字典,類似於java中HashMa ...


redis入門

redis的常見五種數據類型

String類型

  • String類型,類似於java中的String類型,常見使用get,set方法。

  • String類型還可以存儲json字元串格式

Hash類型

  • Hash類型,也叫散列,它的value是一個無序字典,類似於java中HashMap

  • Hash類型的常用命令:

List類型:

  • Redis中的List類型與java中的LinkedList相類似,可以看做一個雙向鏈表的結構,即支持正向檢索,又支持反向檢索。

  • 特征也與java的LinkedList類似

    有序

    元素可重覆

    插入和刪除速度快

    查詢速度一般

  • List類型常用命令

  • 使用List模擬棧、隊列、阻塞隊列

Set類型

Redis的Set結構與Java中的HashSet類似,可以看做是一個value為null的HashMap。因為也是一個hash表,因此具備與HashSet類似的特征:

  • 無序
  • 元素不可重覆
  • 查找快
  • 支持並集,交集,差集

Set常用命令:

redis實戰(黑馬點評)

簡訊驗證碼的登錄註冊功能

商家查詢的緩存功能

redis緩存:查詢的時候先查詢redis,redis有直接返回,redis沒有再查資料庫

1、緩存更新

緩存更新的三種策略

記憶體淘汰:redis自帶的記憶體淘汰機制

過期淘汰:利用expire命令給數據設置過期時間(TTL)

主動更新:主動完成資料庫與緩存的同時更新

主動更新的三種方案

策略選擇

低一致性需求:記憶體淘汰或過期淘汰

高一致性需求:主動更新為主,過期淘汰兜底

Cache Aside模式的選擇

  1. 更新緩存還是刪除緩存?

    更新緩存會產生很多無效更新,並存在較大的線程安全問題。

    刪除緩存本質是延遲更新,沒有無效更新,線程安全問題相對較低

  2. 先操作資料庫還是緩存?

    先更新數據,再刪除緩存——在滿足原子性的情況下,安全問題概率較低

    先刪除緩存,再更新資料庫——安全問題概率較高

  3. 如何確保資料庫與緩存操作原子性

    單體系統——利用事務機制

    分散式系統——使用分散式事務

最佳實踐

查詢數據時:

  1. 先查詢緩存
  2. 如果緩存命中,直接返回
  3. 如果緩存未命中,則查詢資料庫
  4. 將資料庫數據寫入緩存
  5. 返回結果

修改資料庫時:

  1. 先修改資料庫
  2. 然後刪除緩存
  3. 增加事務,確保兩者的原子性

2、緩存穿透

產生原因

客戶端請求的數據在緩存中和資料庫中都不存在,這樣緩存永遠不會生效,這些請求都會打到資料庫

解決方案

緩存空對象

對於不存在的數據也在redis、建立緩存,值為空,並設置一個較短的TTl時間

布隆過濾

利用布隆過濾演算法,在請求進去redis之前先判斷是否存在,如果不存在則直接拒絕請求

其他

3、緩存雪崩

產生原因

在同一時段大量的緩存key同時失效或者redis服務宕機,導致大量請求到達資料庫,帶來巨大壓力。

解決方案

4、緩存擊穿(熱點key)

產生原因

熱點key在某一時間被高併發訪問,緩存重建好事較長。

熱點key突然過期,因為重建耗時長,在這段時間內大量請求落到資料庫,帶來巨大衝擊

解決方案

互斥鎖

邏輯過期


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

-Advertisement-
Play Games
更多相關文章
  • getIRC-Best IRC Client for mac是一款實用的IRC客戶端,它由各種獨立的 IRC 伺服器網路(或“網路”)組成,這些機器允許用戶連接到 IRC。 詳情:getIRC-Best IRC Client for mac(IRC客戶端) 簡單介紹 macOS 上的 Interne ...
  • 有人相愛,有人夜裡開車看海,我是leetcode第一題都做不出來 題目 給定一個整數數組 nums 和一個整數目標值 target,請你在該數組中找出 和為目標值 target 的那 兩個 整數,並返回它們的數組下標。 你可以假設每種輸入只會對應一個答案。但是,數組中同一個元素在答案里不能重覆出現。 ...
  • Vue3 使用v-md-editor如何動態上傳圖片了 前端代碼: <v-md-editor :autofocus="true" v-model="blog.content" height="510px" placeholder="請輸入內容" left-toolbar="undo redo cle ...
  • 該案例主要是實現的功能有:添加商品功能,將商品添加到購物車的功能還有將商品刪除功能,還有就是移出購物車的功能 該案例實現的難點是將商品添加到購物車列表的時候 數量的增加,當購物車有該商品的時候就進行累加操作,沒有該商品就賦值為1. 上代碼: <!DOCTYPE html> <html lang="e ...
  • 樣式的衝突 當我們通過不同的選擇器,選中相同的元素,並且為相同的樣式設置不同的值時,此時就發生了樣式的衝突。 案例一:使用類選擇器與元素選擇器選中同一元素,設置不同顏色 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> ...
  • 閑來無事,總結一下公司使用的 微服務框架,文章所有代碼GtiHub:https://github.com/Tom-shushu/work-study 裡面的gateway-server和server1項目 1、Docker 部署 Nacos 資料庫準備 新建 "nacos_config" 資料庫 # ...
  • C語言的迴圈結構,有for(;;)迴圈,while()迴圈,do~while()迴圈,for迴圈使用最頻繁,三種語句都可以銜接break;continue;來進行中斷迴圈。 在for(;;)迴圈結構中,分號所隔開的語句是(初始化;判斷;調整),當都省略時即直接使用for(;;)時,預設為真,即進入死 ...
  • TortoiseGit 人稱小烏龜插件是一個來源的版本控制客戶端,和git功能類似, 不過相對於git支持界面操作. TortoiseGit下載地址: 點我下載 當前穩定版本是2.6.0, 建議下載此版本, 下麵是下載過程(winx64位系統): 預設是英文安裝, 需要中文的情況可以下載中文語言包 ...
一周排行
    -Advertisement-
    Play Games
  • 基於.NET Framework 4.8 開發的深度學習模型部署測試平臺,提供了YOLO框架的主流系列模型,包括YOLOv8~v9,以及其系列下的Det、Seg、Pose、Obb、Cls等應用場景,同時支持圖像與視頻檢測。模型部署引擎使用的是OpenVINO™、TensorRT、ONNX runti... ...
  • 十年沉澱,重啟開發之路 十年前,我沉浸在開發的海洋中,每日與代碼為伍,與演算法共舞。那時的我,滿懷激情,對技術的追求近乎狂熱。然而,隨著歲月的流逝,生活的忙碌逐漸占據了我的大部分時間,讓我無暇顧及技術的沉澱與積累。 十年間,我經歷了職業生涯的起伏和變遷。從初出茅廬的菜鳥到逐漸嶄露頭角的開發者,我見證了 ...
  • C# 是一種簡單、現代、面向對象和類型安全的編程語言。.NET 是由 Microsoft 創建的開發平臺,平臺包含了語言規範、工具、運行,支持開發各種應用,如Web、移動、桌面等。.NET框架有多個實現,如.NET Framework、.NET Core(及後續的.NET 5+版本),以及社區版本M... ...
  • 前言 本文介紹瞭如何使用三菱提供的MX Component插件實現對三菱PLC軟元件數據的讀寫,記錄了使用電腦模擬,模擬PLC,直至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1. PLC開發編程環境GX Works2,GX Works2下載鏈接 https:// ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • 1、jQuery介紹 jQuery是什麼 jQuery是一個快速、簡潔的JavaScript框架,是繼Prototype之後又一個優秀的JavaScript代碼庫(或JavaScript框架)。jQuery設計的宗旨是“write Less,Do More”,即倡導寫更少的代碼,做更多的事情。它封裝 ...
  • 前言 之前的文章把js引擎(aardio封裝庫) 微軟開源的js引擎(ChakraCore))寫好了,這篇文章整點js代碼來測一下bug。測試網站:https://fanyi.youdao.com/index.html#/ 逆向思路 逆向思路可以看有道翻譯js逆向(MD5加密,AES加密)附完整源碼 ...
  • 引言 現代的操作系統(Windows,Linux,Mac OS)等都可以同時打開多個軟體(任務),這些軟體在我們的感知上是同時運行的,例如我們可以一邊瀏覽網頁,一邊聽音樂。而CPU執行代碼同一時間只能執行一條,但即使我們的電腦是單核CPU也可以同時運行多個任務,如下圖所示,這是因為我們的 CPU 的 ...
  • 掌握使用Python進行文本英文統計的基本方法,並瞭解如何進一步優化和擴展這些方法,以應對更複雜的文本分析任務。 ...
  • 背景 Redis多數據源常見的場景: 分區數據處理:當數據量增長時,單個Redis實例可能無法處理所有的數據。通過使用多個Redis數據源,可以將數據分區存儲在不同的實例中,使得數據處理更加高效。 多租戶應用程式:對於多租戶應用程式,每個租戶可以擁有自己的Redis數據源,以確保數據隔離和安全性。 ...