一文瞭解:Redis事務

来源:https://www.cnblogs.com/imeng/archive/2019/08/06/11307319.html
-Advertisement-
Play Games

Redis事務 事務提供了一種"將多個命令打包,一次性提交並按順序執行"的機制,提交後在事務執行中不會中斷。只有在執行完所有命令後才會繼續執行來自其他客戶的消息。 Redis中的使用 Redis通過multi,exec,discard,watch實現事務功能。 1. multi:開始事務 2. ex ...


Redis事務

事務提供了一種"將多個命令打包,一次性提交並按順序執行"的機制,提交後在事務執行中不會中斷。只有在執行完所有命令後才會繼續執行來自其他客戶的消息。

Redis中的使用

Redis通過multi,exec,discard,watch實現事務功能。

  1. multi:開始事務
  2. exec:提交事務並執行
  3. discard:取消事務
  4. watch:事務開始之前監視任意數量的鍵
> multi
OK
> set bookName "Redis"
QUEUED
> get bookName
QUEUED
> sadd tag "Redis" "New Book"
QUEUED
> smembers tag
QUEUED
> exec
1) OK
2) "Redis"
3) (integer) 2
4) 1) "Redis"
   2) "New Book"

開始事務

> multi
OK

這個命令將Redis_multi選項打開,讓客戶端從非事務狀態變為事務狀態

multi命令

命令入隊

> set bookName "Redis"
QUEUED
> get bookName
QUEUED
> sadd tag "Redis" "New Book"
QUEUED
> smembers tag
QUEUED

在事務狀態中,Redis命令並不是立即執行的,而是進入一個先進先出的事務隊列。QUEUED表示這個命令已經入了事務隊列。

執行事務

> exec
1) OK
2) "Redis"
3) (integer) 2
4) 1) "Redis"
   2) "New Book"

當執行exec命令時,Redis根據客戶端所保存的事務隊列, 以先進先出的方式執行事務隊列中的命令: 最先入隊的命令最先執行, 而最後入隊的命令最後執行。
當exec命令執行完畢時,Redis會將結果保存到一個回覆隊列,並將回覆隊列返回給客戶端。客戶端從事務狀態退出,一個事務執行完畢。

discard命令

> multi
OK
> set author "lisi"
QUEUED
> discard
OK
> get author
(nil)

discard取消一個事務的命令,表示這個事務被取消。客戶端從事務狀態退出,回到非事務狀態,Redis_multi選項關閉。

事務中exec和discard

watch命令

# Redis客戶端1
> watch letter
OK
> multi
OK
> set letter a
QUEUED
> exec
(nil)


# Redis客戶端2
> set letter b
OK

# Redis客戶端1
> get letter
"b"

設置監控letter鍵,客戶端1進入事務,設置letter的value為a,未提交事務。客戶端2設置letter的value為b。回到客戶端1提交事務返回的結果為nil,調用get命令得到letter為b。這說明當letter鍵在其他客戶端改變後,事務被取消了,不會被執行,返回失敗。

watch命令在事務開始之前監視任意數量的鍵:當調用exce命令執行事務時,如果任意一個被監視的鍵已經被其他客戶端修改了,那麼整個事務不再執行,直接返回失敗。

watch命令

事務異常

命令錯誤

> set letter ac
QUEUED
> get letter ac
(error) ERR wrong number of arguments for 'get' command
> exec
(error) EXECABORT Transaction discarded because of previous errors.

事務中命令異常屬於語法錯誤,將導致事務無法執行。

運行時異常

> multi
OK
> lpush books "Redis"
QUEUED
> incr books
QUEUED
> lpush books "Python"
QUEUED
> lrange books 0 -1
QUEUED
> exec
1) (integer) 1
2) (error) WRONGTYPE Operation against a key holding the wrong kind of value
3) (integer) 2
4) 1) "Python"
   2) "Redis"

上面的例子是事務執行到中間遇到失敗了,因為不能對一個字元串進行incr命令,事務在遇到命令執行失敗後,後續的命令還繼續執行,所以books的值能繼續得到設置。這種異常只有程式員在代碼中避免。

事務的ACID

原子性

原子意味著要麼一起成功執行,要麼一起失敗回滾。Redis提供的所有API都是原子操作。那麼Redis事務只要保證在一批操作中保證原子性,但是在運行時異常中,在一個事務中一個命令出現異常,其他命令還是會繼續執行,事務沒有回滾機制,所以Redis事務是不保證原子性的。

一致性

事務異常

如果命令錯誤事務無法執行,如果是運行時異常,Redis會將錯誤包含在返回結果中,並不影響後續執行,所以事務是一致性的。

Redis進程被終結

在純記憶體模式下,Redis沒有做持久化,重啟之後資料庫是空白的,所以是事務一致性的。

在RDB模式下,事務並不會在中途執行保存RDB文件的工作,只有在事務執行完後,RDB工作才可能會開始。所以在事務執行過程中Redis進程被殺死,不管成功多少都不會保存到RDB文件中,所以是一致性的。

在AOF模式下,事務部分語句被寫入AOF文件並保存成功,不完整的事務被保存到了AOF文件,當重啟Redis時,檢查AOF文件不完整,Redis退出並報錯。需要把這段不完整的事務刪除後才能重啟成功,所以是一致性的。

在AOF模式下,事務並未被寫入AOF文件,所以重啟後Redis資料庫是最近一次成功保存到AOF文件中的數據。並沒有這次事務的數據,所以是以一致性的。

隔離性

Redis 是單進程程式,並且它保證在執行事務時,不會對事務進行中斷,事務可以運行直到執行完所有事務隊列中的命令為止。所以事務是帶有隔離性的。

持久性

在純記憶體模式下,事務肯定不是持續性的。

在RDB模式下,伺服器可能在事務執行之後、RDB文件更新之前的這段時間失敗,所以 RDB模式下的事務也是不持久的。

在AOF模式下,將命令添加到AOF文件中,但是對文件進行寫入並不會馬上寫到磁碟上,而是先存儲到緩衝區。所以數據保存到磁碟上有一段非常小的時間間隔。這種模式下事務也不是持久的。

結語

本人深知水平有限,歡迎指正本文錯誤之處。

參考資料

《Redis 設計與實現》

《Redis 開發與運維》

《Redis 深度歷險:核心原理與應用實踐》


歡迎關註公眾號:bate喵

專註於Java相關技術:Linux、JVM、SpringCloud、SpringBoot、Docker、Redis、Netty、微服務、高併發等領域,偶爾聊聊學習之道、自控力等方法,致力於成就更好的自己,歡迎大家關註交流,共同成長


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

-Advertisement-
Play Games
更多相關文章
  • 1. 遷移背景和限制條件 隨著功能的迭代或者數據表中數據量的增加,將現有數據進行遷移已是工作中經常遇到的事情。通常我們在平時遷移數據數據的時候,只需要用mysqldump、mysqlimport指令就能完成遷移功能,但在實際工作中,作為開發者的我們往往沒有這麼大的許可權(例如寫許可權)來操作線上數據,只 ...
  • 目前最流行的大數據查詢引擎非hive莫屬,它是基於MR的類SQL查詢工具,會把輸入的查詢SQL解釋為MapReduce,能極大的降低使用大數據查詢的門檻, 讓一般的業務人員也可以直接對大數據進行查詢。但因其基於MR,運行速度是一個弊端,通常運行一個查詢需等待很久才會有結果。對於此情況,創造了hive ...
  • 一、創建表 create table 表裡包含什麼類型的數據 表的名稱是什麼 主鍵 列的名稱是什麼 每一列的數據類型是什麼 每一列的長度是多少 表裡哪些列可以是空的 語法: create table table_name (field1 data_type [not null], field2 da ...
  • 1. MySQL多表查詢 1.1 外鍵約束 為了消除多張表查詢出現的笛卡爾積的現象,MySQL在建表併進行多表之間的關鍵查詢可以使用外鍵關聯查詢。 外鍵:從表1(sub)的某列引用(ref)另外一個表2(main)的某列的值,把表1的這列叫做表2這列的外鍵。 1.2 外鍵的設置使用 比如上述最簡單的 ...
  • zookeeper是幹嘛的呢 Zookeeper的作用1.可以為客戶端管理少量的數據kvkey:是以路徑的形式表示的,那就意味著,各key之間有父子關係,比如/ 是頂層key用戶建的key只能在/ 下作為子節點,比如建一個key: /aa 這個key可以帶value數據也可以建一個key: /bb也 ...
  • 通過https://www.cnblogs.com/tree1123/p/11243668.html 已經對consumer有了一定的瞭解。producer比consumer要簡單一些。 一、舊版本producer 0.9.0.0版本以前,是由scala編寫的舊版本producer。 入口類:kaf ...
  • 恢復內容開始 Windows下備份mysql 第一步 編寫腳本 --user 用戶名 --password 密碼 --host 地址 --port 埠 --default-character-set 字元編碼 --all-databases 備份整個資料庫 (單單備份一個庫可用--database ...
  • 前言 由於最近在學習node+express,學習到持久化存儲章節需要連接mongodb資料庫,然後之前也有試過安裝mongodb但是失敗了,這次就找了很多資料,終於安裝完成了,故此記錄下來安裝步驟,提供給有需要的人. 安裝流程 1. 下載mongodb安裝包 官網地址:https://www.mo ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...