欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

一文教你學會Redis的事務

 更新時間:2022年08月03日 10:02:47   作者:指北君  
Redis?作為內存的存儲中間件,已經是面試的面試題必問之一了。今天小編就來和大家一起來聊聊Redis的事務吧,希望對大家有所幫助

Redis 作為內存的存儲中間件,已經是面試的面試題必問之一了,今天一起來看看 Redis 的事務吧。

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

Redis 中的使用

Redis 通過 multi,exec,discard,watch 實現(xiàn)事務功能。

  • multi:開始事務
  • exec:提交事務并執(zhí)行
  • discard:取消事務
  • watch:事務開始之前監(jiān)視任意數(shù)量的鍵
>?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 選項打開,讓客戶端從非事務狀態(tài)變?yōu)槭聞諣顟B(tài)

命令入隊

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

在事務狀態(tài)中,Redis 命令并不是立即執(zhí)行的,而是進入一個先進先出的事務隊列。QUEUED 表示這個命令已經入了事務隊列。

執(zhí)行事務

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

當執(zhí)行 exec 命令時,Redis 根據(jù)客戶端所保存的事務隊列, 以先進先出的方式執(zhí)行事務隊列中的命令:最先入隊的命令最先執(zhí)行, 而最后入隊的命令最后執(zhí)行。當 exec 命令執(zhí)行完畢時,Redis 會將結果保存到一個回復隊列,并將回復隊列返回給客戶端??蛻舳藦氖聞諣顟B(tài)退出,一個事務執(zhí)行完畢。

discard 命令

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

discard 取消一個事務的命令,表示這個事務被取消??蛻舳藦氖聞諣顟B(tài)退出,回到非事務狀態(tài),Redis_multi 選項關閉。

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"

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

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

事務異常

命令錯誤

>?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.

事務中命令異常屬于語法錯誤,將導致事務無法執(zhí)行。

運行時異常

>?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"

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

事務的 ACID

原子性

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

一致性

事務異常

如果命令錯誤事務無法執(zhí)行,如果是運行時異常,Redis 會將錯誤包含在返回結果中,并不影響后續(xù)執(zhí)行,所以事務是一致性的。

Redis 進程被終結

在純內存模式下,Redis 沒有做持久化,重啟之后數(shù)據(jù)庫是空白的,所以是事務一致性的。

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

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

在 AOF 模式下,事務并未被寫入 AOF 文件,所以重啟后 Redis 數(shù)據(jù)庫是最近一次成功保存到 AOF 文件中的數(shù)據(jù)。并沒有這次事務的數(shù)據(jù),所以是以一致性的。

隔離性

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

持久

在純內存模式下,事務肯定不是持續(xù)性的。

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

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

結語

本文介紹了 Redis 的事務的 multi,exec,discard,watch  命令用法和 它的 ACID。

到此這篇關于一文教你學會Redis的事務的文章就介紹到這了,更多相關Redis事務內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 壓縮列表犧牲速度來節(jié)省內存,Redis是膨脹了嗎

    壓縮列表犧牲速度來節(jié)省內存,Redis是膨脹了嗎

    這篇文章主要給大家解釋了Redis 當中的 ziplist(壓縮列表)犧牲速度來節(jié)省內存的原因,希望大家能夠喜歡
    2021-02-02
  • 分布式利器redis及redisson的延遲隊列實踐

    分布式利器redis及redisson的延遲隊列實踐

    這篇文章為大家主要介紹了分布式利器redis及redisson的延遲隊列實踐,搜遍全網好像還沒有使用redisson的延遲隊列的,redisson作為一個分布式利器,這么好用的工具沒人用有點可惜
    2022-03-03
  • 基于Redis實現(xiàn)阻塞隊列的方式

    基于Redis實現(xiàn)阻塞隊列的方式

    本文主要講解基于?Redis?的方式實現(xiàn)異步隊列,基于?Redis?的?list?實現(xiàn)隊列的方式也有多種,本文通過實例代碼給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧
    2021-12-12
  • 使用Redis實現(xiàn)微信步數(shù)排行榜功能

    使用Redis實現(xiàn)微信步數(shù)排行榜功能

    這篇文章主要介紹了使用Redis實現(xiàn)微信步數(shù)排行榜功能,本文通過圖文實例代碼相結合給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • Redis序列化設置以及jetcache連接Redis序列化的設置過程

    Redis序列化設置以及jetcache連接Redis序列化的設置過程

    這篇文章主要介紹了Redis序列化設置以及jetcache連接Redis序列化的設置過程,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Redis分布式鎖之紅鎖的實現(xiàn)

    Redis分布式鎖之紅鎖的實現(xiàn)

    本文主要介紹了Redis分布式鎖之紅鎖的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-08-08
  • redis.config配置文件

    redis.config配置文件

    在使用Redis時,我們通常需要對Redis進行一些配置,以確保其能夠正常運行并滿足我們的需求,本文主要介紹了redis.config配置文件,感興趣的可以了解一下
    2023-11-11
  • 使用redis實現(xiàn)附近的人功能

    使用redis實現(xiàn)附近的人功能

    這篇文章主要介紹了使用redis實現(xiàn)附近的人,實現(xiàn)諸如附近的人這類依賴于地理位置信息的功能,本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2021-09-09
  • 解決redis在linux上的部署的問題

    解決redis在linux上的部署的問題

    這篇文章主要介紹了redis在linux上的部署,本文分步驟給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-02-02
  • Redis實現(xiàn)分布式鎖的示例代碼

    Redis實現(xiàn)分布式鎖的示例代碼

    日常開發(fā)中,秒殺下單、搶紅包等等業(yè)務場景,都需要用到分布式鎖,本文主要介紹了Redis實現(xiàn)分布式鎖的示例代碼,感興趣的可以了解一下
    2023-10-10

最新評論