multi OK > set bookName "Redis" QUEUED > get" />

RM新时代网站-首页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Redis中的使用

科技綠洲 ? 來(lái)源:Java技術(shù)指北 ? 作者:Java技術(shù)指北 ? 2023-10-08 15:27 ? 次閱讀

Redis 作為內(nèi)存的存儲(chǔ)中間件,已經(jīng)是面試的面試題必問(wèn)之一了,今天一起來(lái)看看 Redis 的事務(wù)吧。

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

Redis 中的使用

Redis 通過(guò) multi,exec,discard,watch 實(shí)現(xiàn)事務(wù)功能。

  1. multi:開始事務(wù)
  2. exec:提交事務(wù)并執(zhí)行
  3. discard:取消事務(wù)
  4. watch:事務(wù)開始之前監(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"

開始事務(wù)

> multi
OK

這個(gè)命令將 Redis_multi 選項(xiàng)打開,讓客戶端從非事務(wù)狀態(tài)變?yōu)槭聞?wù)狀態(tài)

圖片

命令入隊(duì)

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

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

執(zhí)行事務(wù)

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

當(dāng)執(zhí)行 exec 命令時(shí),Redis 根據(jù)客戶端所保存的事務(wù)隊(duì)列, 以先進(jìn)先出的方式執(zhí)行事務(wù)隊(duì)列中的命令:最先入隊(duì)的命令最先執(zhí)行, 而最后入隊(duì)的命令最后執(zhí)行。當(dāng) exec 命令執(zhí)行完畢時(shí),Redis 會(huì)將結(jié)果保存到一個(gè)回復(fù)隊(duì)列,并將回復(fù)隊(duì)列返回給客戶端??蛻舳藦氖聞?wù)狀態(tài)退出,一個(gè)事務(wù)執(zhí)行完畢。

discard 命令

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

discard 取消一個(gè)事務(wù)的命令,表示這個(gè)事務(wù)被取消??蛻舳藦氖聞?wù)狀態(tài)退出,回到非事務(wù)狀態(tài),Redis_multi 選項(xiàng)關(guān)閉。

圖片

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"

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

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

圖片

事務(wù)異常

命令錯(cuò)誤

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

事務(wù)中命令異常屬于語(yǔ)法錯(cuò)誤,將導(dǎo)致事務(wù)無(wú)法執(zhí)行。

運(yùn)行時(shí)異常

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

上面的例子是事務(wù)執(zhí)行到中間遇到失敗了,因?yàn)椴荒軐?duì)一個(gè)字符串進(jìn)行 incr 命令,事務(wù)在遇到命令執(zhí)行失敗后,后續(xù)的命令還繼續(xù)執(zhí)行,所以 books 的值能繼續(xù)得到設(shè)置。這種異常只有程序員在代碼中避免。

事務(wù)的 ACID

原子性

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

一致性

事務(wù)異常

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

Redis 進(jìn)程被終結(jié)

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

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

在 AOF 模式下,事務(wù)部分語(yǔ)句被寫入 AOF 文件并保存成功,不完整的事務(wù)被保存到了 AOF 文件,當(dāng)重啟 Redis 時(shí),檢查 AOF 文件不完整,Redis 退出并報(bào)錯(cuò)。需要把這段不完整的事務(wù)刪除后才能重啟成功,所以是一致性的。

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

隔離性

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

持久

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

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

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

結(jié)語(yǔ)

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

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 存儲(chǔ)
    +關(guān)注

    關(guān)注

    13

    文章

    4296

    瀏覽量

    85798
  • DISCARD
    +關(guān)注

    關(guān)注

    0

    文章

    2

    瀏覽量

    6458
  • 客戶端
    +關(guān)注

    關(guān)注

    1

    文章

    290

    瀏覽量

    16683
  • Redis
    +關(guān)注

    關(guān)注

    0

    文章

    374

    瀏覽量

    10871
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    #硬聲創(chuàng)作季 SSG分布式鎖視頻教程:20.演示Redis的超賣現(xiàn)象

    數(shù)據(jù)庫(kù)Redis
    Mr_haohao
    發(fā)布于 :2022年10月02日 23:08:26

    Simple Dynamic Strings (簡(jiǎn)稱 SDS) 是什么

    語(yǔ)言字符串處理的能力。設(shè)計(jì) SDS 原本是為了滿足設(shè)計(jì)者自身日常的 C 編程,后來(lái)又被轉(zhuǎn)移到 Redis ,在 Redis 中被廣泛使用并對(duì)其進(jìn)行了修改以適合于高性能操作?,F(xiàn)在,它又被從
    發(fā)表于 07-16 06:45

    如何使得redis的數(shù)據(jù)不再有

    嵌入式Linux系統(tǒng)重啟后如何使得redis的數(shù)據(jù)不再有今天在工作遇到一個(gè)問(wèn)題:網(wǎng)頁(yè)展示redis的數(shù)據(jù),然而再Linux系統(tǒng)重啟后網(wǎng)
    發(fā)表于 11-05 08:50

    關(guān)于redis數(shù)據(jù)存儲(chǔ)的機(jī)制解析

    不同于memcached等完全基于內(nèi)存的緩存中間件,Redis同時(shí)還提供了持久化功能,這也是為什么Redis不僅可以用來(lái)做數(shù)據(jù)緩存還可以用來(lái)做數(shù)據(jù)存儲(chǔ),服務(wù)器節(jié)點(diǎn)宕機(jī)之后可以通過(guò)事先持久化的數(shù)據(jù)還原數(shù)據(jù)到某個(gè)時(shí)間點(diǎn)的狀態(tài)。
    發(fā)表于 09-02 10:46 ?1124次閱讀
    關(guān)于<b class='flag-5'>redis</b><b class='flag-5'>中</b>數(shù)據(jù)存儲(chǔ)的機(jī)制解析

    嵌入式Linux系統(tǒng)重啟后如何使得redis的數(shù)據(jù)不再有

    嵌入式Linux系統(tǒng)重啟后如何使得redis的數(shù)據(jù)不再有今天在工作遇到一個(gè)問(wèn)題:網(wǎng)頁(yè)展示redis的數(shù)據(jù),然而再Linux系統(tǒng)重啟后網(wǎng)
    發(fā)表于 11-02 15:06 ?11次下載
    嵌入式Linux系統(tǒng)重啟后如何使得<b class='flag-5'>redis</b><b class='flag-5'>中</b>的數(shù)據(jù)不再有

    Redis的數(shù)據(jù)類型為何同時(shí)采用兩種數(shù)據(jù)結(jié)構(gòu)來(lái)進(jìn)行分別存儲(chǔ)呢

    Redis 的集合對(duì)象是一個(gè)包含字符串類型元素的無(wú)序集合,集合中元素唯一不可重復(fù)。
    的頭像 發(fā)表于 08-17 11:26 ?1165次閱讀
    <b class='flag-5'>Redis</b>的數(shù)據(jù)類型為何同時(shí)采用兩種數(shù)據(jù)結(jié)構(gòu)來(lái)進(jìn)行分別存儲(chǔ)呢

    基于排行榜功能使用redis的有序集合實(shí)現(xiàn)

    排行榜功能是一個(gè)很普遍的需求,對(duì)于這類需求如果數(shù)據(jù)總量過(guò)大用mysql實(shí)現(xiàn)的話會(huì)很浪費(fèi)性能。
    的頭像 發(fā)表于 10-21 09:59 ?1013次閱讀

    如何使用Redis更節(jié)省內(nèi)存?

    當(dāng)你的業(yè)務(wù)應(yīng)用在 Redis 存儲(chǔ)數(shù)據(jù)很少時(shí),你可能并不太關(guān)心內(nèi)存資源的使用情況。但隨著業(yè)務(wù)的發(fā)展,你的業(yè)務(wù)存儲(chǔ)在 Redis 的數(shù)據(jù)就會(huì)越來(lái)越多。
    的頭像 發(fā)表于 12-19 15:41 ?945次閱讀

    SpringBoot+Redis實(shí)現(xiàn)點(diǎn)贊功能的緩存和定時(shí)持久化(附源碼)

    用戶對(duì)瀏覽內(nèi)容進(jìn)行【點(diǎn)贊/取贊】,并發(fā)送【點(diǎn)贊/取贊】請(qǐng)求到后端,這些信息先存入Redis緩存,再每隔兩小時(shí)將Redis的內(nèi)容直接寫入數(shù)據(jù)庫(kù)持久化存儲(chǔ)。
    的頭像 發(fā)表于 02-09 16:38 ?4556次閱讀

    為什么要使用Redis做緩存?

    Java里提供了HashMap,Redis也有類似的數(shù)據(jù)結(jié)構(gòu),就是哈希類型。但是要注意,哈希類型的映射關(guān)系叫作field-value,注意這里的value是指field對(duì)應(yīng)的值,不是鍵對(duì)應(yīng)的值。
    的頭像 發(fā)表于 03-13 09:50 ?2450次閱讀

    如何從0到1構(gòu)建一個(gè)穩(wěn)定、高性能的Redis集群?

    這個(gè)架構(gòu)非常簡(jiǎn)單,你的業(yè)務(wù)應(yīng)用可以把 Redis 當(dāng)做緩存來(lái)使用,從 MySQL 查詢數(shù)據(jù),然后寫入到 Redis ,之后業(yè)務(wù)應(yīng)用再?gòu)?Redi
    的頭像 發(fā)表于 07-19 15:19 ?631次閱讀
    如何從0到1構(gòu)建一個(gè)穩(wěn)定、高性能的<b class='flag-5'>Redis</b>集群?

    Redis架構(gòu)演化之路

    這個(gè)架構(gòu)非常簡(jiǎn)單,你的業(yè)務(wù)應(yīng)用可以把 Redis 當(dāng)做緩存來(lái)使用,從 MySQL 查詢數(shù)據(jù),然后寫入到 Redis ,之后業(yè)務(wù)應(yīng)用再?gòu)?Redi
    的頭像 發(fā)表于 08-03 16:54 ?607次閱讀
    <b class='flag-5'>Redis</b>架構(gòu)演化之路

    redis查看主從節(jié)點(diǎn)命令

    Redis是一種開源的內(nèi)存數(shù)據(jù)結(jié)構(gòu)存儲(chǔ)系統(tǒng),常被用作數(shù)據(jù)庫(kù)、緩存和消息中間件。在Redis,可以通過(guò)一些命令來(lái)查看主從節(jié)點(diǎn)的信息,以便進(jìn)行監(jiān)控和管理。 Redis 主從復(fù)制是指將一個(gè)
    的頭像 發(fā)表于 12-04 11:44 ?1318次閱讀

    redis hash底層實(shí)現(xiàn)原理

    Redis是一個(gè)開源的內(nèi)存數(shù)據(jù)庫(kù),使用鍵值對(duì)存儲(chǔ)數(shù)據(jù)。其中,Redis的數(shù)據(jù)結(jié)構(gòu)之一就是哈希(Hash),它提供了一種將多個(gè)字段(Field)存儲(chǔ)在一個(gè)鍵(Key)的方法。那么
    的頭像 發(fā)表于 12-04 16:27 ?581次閱讀

    redis容器運(yùn)行時(shí)間久了會(huì)自動(dòng)執(zhí)行flushdb

    Redis是一種開源的內(nèi)存數(shù)據(jù)庫(kù),常用于緩存、消息傳遞、持久化等場(chǎng)景。在Redis,flushdb命令用于清空當(dāng)前數(shù)據(jù)庫(kù)的所有數(shù)據(jù)。然而,Red
    的頭像 發(fā)表于 12-05 10:12 ?954次閱讀
    RM新时代网站-首页