Redis 小白指南(三)- 事務、過期、消息通知、管道和優化記憶體空間

来源:http://www.cnblogs.com/liqingwen/archive/2017/06/04/6920680.html
-Advertisement-
Play Games

Redis 小白指南(三)- 事務、過期、消息通知、管道和優化記憶體空間 簡介 《Redis 小白指南(一)- 簡介、安裝、GUI 和 C# 驅動介紹》 講的是 Redis 的介紹,以及如何在 Windows 上安裝並使用,一些 GUI 工具和自己簡單封裝的 RedisHelper。 《Redis 小 ...


Redis 小白指南(三)- 事務、過期、消息通知、管道和優化記憶體空間

簡介

  《Redis 小白指南(一)- 簡介、安裝、GUI 和 C# 驅動介紹》 講的是 Redis 的介紹,以及如何在 Windows 上安裝並使用,一些 GUI 工具和自己簡單封裝的 RedisHelper。

  《Redis 小白指南(二)- 聊聊五大類型:字元串、散列、列表、集合和有序集合》講的是 Redis 中最核心的內容,最常用的就是和數據類型打交道。

 

目錄

  • 事務
  • 過期時間
  • 消息通知
  • 管道
  • 優化記憶體空間

 

事務

  事務是一組命令的集合,事務和命令一樣都是 Redis 的最小執行單位。即一個事務中的命令,要麼都執行,要麼都不執行。可以思考關係型資料庫中的事務特性 ACID:

    (1)原子性(Atomicity):在事務結束時,其中包含的更新處理要麼全部執行,要麼完全不執行。

    (2)一致性(Consistency):事務中包含的處理,要滿足資料庫提前設置的約束,也稱完整性。

    (3)隔離性(lsolation):保證不同事務之前互不幹擾的特性。

    (4)持久性(Durability):事務一旦結束,DBMS 會保證該時點的數據狀態得以保存的特性,也稱耐久性。

 

  Redis 可以保證一個事務中的命令依次執行而不會被其它命令插入。如:Client A 需要執行多條指令,同時 Client B 也執行多條指令,因為網路傳輸或者時間等因素造成指令發送到 Redis 伺服器的順序有先後,即有可能會出現 A 發送的指令和 B 發送的指令形成了交叉,使用事務就可以避免這種情況。

  遺憾的是,Redis 不支持回滾。

 

MULTI    //開啟事務的指令

EXEC    //執行事務,依次執行

 

  當客戶端發送了 EXEC 的指令後,即使客戶端此時突然斷開與伺服器的鏈接,事務中的操作依然會依次執行,因為他們都已經被緩存到 Redis 事務的隊列中了。

 

過期時間

  1.設置過期時間意味著一段時間後就會刪除 redis 中指定的數據。

  2.應用場景:限時優惠活動、緩存、學校成績排名定期刷新。

  

  3.命令:

  (1)EXPIRE:

EXPIRE key seconds  //seconds 參數表示鍵的過期時間,單位是秒

 

  (2)TTL:查看剩餘時間

TTL key

 

  (3)DEL:刪除

DEL key

 

  (4)PERSIST:取消鍵的過期時間設置(將該鍵切換成永久性質的)

PERSIST key

 

消息通知

  1.什麼情況才會使用呢?

  答:比如,我們的網站進行一些比較耗時的操作時,如發送郵件、複雜的數據運算和 IO 日誌記錄等都可以使用,因為這樣可以避免阻塞前端頁面的渲染,避免用戶進行長時間的等待。一般我們會使用多線程和非同步進行處理這種耗時操作的問題。

 

  2.什麼是消息通知?

  答:你可以理解為常說的消息隊列,類似設計模式中的生產/消費模式,一邊是生產者(producer),一邊是消費者(consumer)。生產者負責把要處理的任務丟到隊列里,消費者負責取出隊列中的任務進行執行。

 

  3.特點:

    松耦合:沒有語言限制,開發團隊可以分別使用不同的開發語言,雙方約定好數據的傳輸格式即可。

    易於擴展:消費者可以有多個,部署在多台伺服器上,輕鬆減輕單台伺服器的壓力。

 

  不過,從大局來看,企業常採用第三方更為專業的 MQ,如 RabbitMQ 替代 Redis 的消息隊列機制。《[.NET] RabbitMQ 的行為藝術》

 

管道

  客戶端和 Redis 採用的是 TCP 進行連接。

  我們對 Redis 發送一條指令後進行等待,完畢後返回執行結果;接著,發送第二條指令,再次等待 Redis 執行完畢後的執行結果;第三次發送指令 ... ...。

  雖然現在的網路帶寬已經足夠快,不過如果執行的命令過多,性能消耗依然是挺明顯的。

  管道機制,它把多條命令一次性組合起來發送到 Redis 伺服器執行,再返回所有的執行結果,與之前的相比減少了兩端網路請求的次數從而提高了性能。

 

優化記憶體空間

  雖然在現在這個年代,記憶體條的價格已經非常便宜,但相對於硬碟來說,價格依然非常高昂,進行記憶體空間成本的控制和資源的有效利用也是一個迫切的主題。

  1.精簡鍵名和鍵值。不過需要自己把握精簡的尺度,因為要基於可讀性的基礎上進行精簡,過於精簡不易於維護也容易造成命名衝突。

  2.選擇合適的數據類型進行存儲。

  3.定時清理(刪除)無效的緩存數據,或者設置自動過期時間。

  4.配置 Redis 可用的最大空間大小,進行資源的合理分配。

 

系列

  《Redis 小白指南(一)- 簡介、安裝、GUI 和 C# 驅動介紹

  《Redis 小白指南(二)- 聊聊五大類型:字元串、散列、列表、集合和有序集合

  《Redis 小白指南(三)- 事務、過期、消息通知、管道和優化記憶體空間》

  《Redis 小白指南(四)- 數據的持久化保存

 

 


【博主】反骨仔

【原文】http://www.cnblogs.com/liqingwen/p/6920680.html 

【GitHub】https://github.com/liqingwen2015/Wen.Helpers/blob/master/Wen.Helpers.Common/Redis/RedisHelper.cs

【參考】《Redis 入門指南》


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

-Advertisement-
Play Games
更多相關文章
  • 問題描述:開啟SQLServer自動備份後,備份文件越來越多,有沒有及時清理,導致伺服器空間不足,備份出錯,以至於出現幾個G的ErrorLog文件,影響系統的登錄管理。 解決辦法:定期清理SQLServer ErrorLog文件。 ...
  • 開啟MySQL的基本語法是grant授權,這個一般都沒有什麼問題,主要是開啟之後可能還是連接不上 可能會出現如下的錯誤提示 確認成功授權之後(具體查看方法在文底),出現如下的問題可能有兩種原因,一種是防火牆問題,一種是MySQL配置綁定了本地127.0.0.1。 一、防火牆問題 防火牆沒有開啟330 ...
  • 1、DDL-增刪改查 (1)SELECT - 獲取數據(SELECT * FROM 表名 WHERE 條件)(2)UPDATE - 更新數據(UPDATE 表名 SET (欄位名=值,欄位名=值) WHERE 條件)(3)DELETE - 刪除數據(DELETE FROM 表名 WHERE 條件)( ...
  • 4月份參加騰訊的實習生面試,初試和覆試的時候都被問到資料庫索引的知識,所以很有必要整理一下這方面的知識。 分為三點,為什麼要用資料庫索引,換句話說它的優點有哪些;什麼情況下適合用資料庫索引呢?怎麼創建資料庫索引,索引有哪些特征呢? (一)為什麼要用資料庫索引? (資料庫索引有哪些優點) ——因為,創 ...
  • Redis大幅性能提升之Batch批量讀寫 提示:本文針對的是StackExchange.Redis 一、問題呈現 前段時間在開發的時候,遇到了redis批量讀的問題,由於在StackExchange.Redis裡面我確實沒有找到PipeLine命令,找到的是Batch命令,因此對其用法進行了探究一 ...
  • [深圳/廣州] 新一期俱樂部活動報名開始,這次是廣深地區SQL Server 技術沙龍分享會(MVP),SQL Server作為一個數據平臺,不管是SQL Server 2017 on Linux 還是把一門開源R語言融入其最賺錢的旗艦商業資料庫,微軟已經決定,下一代的由雲驅動的計算將以數據驅動的智 ...
  • 轉載:http://www.cnblogs.com/xqzt/p/5034375.html 對於熟悉Oracle或者接觸過Oracle的人,scott這個用戶大家一定相當的熟悉。12c推出了可插拔資料庫,在一個容器cdb中以多租戶的形式同時存在多個資料庫pdb。pdb中預設不包含scott用戶。 為 ...
  • 使用SSH之類的工具或navicat鏈接資料庫後(註意:是鏈接資料庫後哦,不是直接SSH後就弄,這樣提示命令錯誤的) 執行下麵命令(目的是對ASTGO的資料庫內除話單之外的所有表進行數據碎片整理,特別是用戶表和充值卡表,壓縮率非常高的) ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...