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

精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Redis中的使用

科技綠洲 ? 來源:Java技術指北 ? 作者:Java技術指北 ? 2023-10-08 15:27 ? 次閱讀

Redis 作為內存的存儲中間件,已經是面試的面試題必問之一了,今天一起來看看 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 選項打開,讓客戶端從非事務狀態變為事務狀態

圖片

命令入隊

> 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 選項關閉。

圖片

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 命令執行事務時,如果任意一個被監視的鍵已經被其他客戶端修改了,那么整個事務不再執行,直接返回失敗。

圖片

事務異常

命令錯誤

> 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 的事務的 multi,exec,discard,watch 命令用法和 它的 ACID。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 存儲
    +關注

    關注

    13

    文章

    4261

    瀏覽量

    85669
  • DISCARD
    +關注

    關注

    0

    文章

    2

    瀏覽量

    6450
  • 客戶端
    +關注

    關注

    1

    文章

    290

    瀏覽量

    16661
  • Redis
    +關注

    關注

    0

    文章

    371

    瀏覽量

    10844
收藏 人收藏

    評論

    相關推薦

    #硬聲創作季 SSG分布式鎖視頻教程:20.演示Redis的超賣現象

    數據庫Redis
    Mr_haohao
    發布于 :2022年10月02日 23:08:26

    Simple Dynamic Strings (簡稱 SDS) 是什么

    語言字符串處理的能力。設計 SDS 原本是為了滿足設計者自身日常的 C 編程,后來又被轉移到 Redis ,在 Redis 中被廣泛使用并對其進行了修改以適合于高性能操作。現在,它又被從
    發表于 07-16 06:45

    如何使得redis的數據不再有

    嵌入式Linux系統重啟后如何使得redis的數據不再有今天在工作遇到一個問題:網頁展示redis的數據,然而再Linux系統重啟后網
    發表于 11-05 08:50

    關于redis數據存儲的機制解析

    不同于memcached等完全基于內存的緩存中間件,Redis同時還提供了持久化功能,這也是為什么Redis不僅可以用來做數據緩存還可以用來做數據存儲,服務器節點宕機之后可以通過事先持久化的數據還原數據到某個時間點的狀態。
    發表于 09-02 10:46 ?1116次閱讀
    關于<b class='flag-5'>redis</b><b class='flag-5'>中</b>數據存儲的機制解析

    嵌入式Linux系統重啟后如何使得redis的數據不再有

    嵌入式Linux系統重啟后如何使得redis的數據不再有今天在工作遇到一個問題:網頁展示redis的數據,然而再Linux系統重啟后網
    發表于 11-02 15:06 ?11次下載
    嵌入式Linux系統重啟后如何使得<b class='flag-5'>redis</b><b class='flag-5'>中</b>的數據不再有

    Redis的數據類型為何同時采用兩種數據結構來進行分別存儲呢

    Redis 的集合對象是一個包含字符串類型元素的無序集合,集合中元素唯一不可重復。
    的頭像 發表于 08-17 11:26 ?1142次閱讀
    <b class='flag-5'>Redis</b>的數據類型為何同時采用兩種數據結構來進行分別存儲呢

    基于排行榜功能使用redis的有序集合實現

    排行榜功能是一個很普遍的需求,對于這類需求如果數據總量過大用mysql實現的話會很浪費性能。
    的頭像 發表于 10-21 09:59 ?985次閱讀

    如何使用Redis更節省內存?

    當你的業務應用在 Redis 存儲數據很少時,你可能并不太關心內存資源的使用情況。但隨著業務的發展,你的業務存儲在 Redis 的數據就會越來越多。
    的頭像 發表于 12-19 15:41 ?911次閱讀

    SpringBoot+Redis實現點贊功能的緩存和定時持久化(附源碼)

    用戶對瀏覽內容進行【點贊/取贊】,并發送【點贊/取贊】請求到后端,這些信息先存入Redis緩存,再每隔兩小時將Redis的內容直接寫入數據庫持久化存儲。
    的頭像 發表于 02-09 16:38 ?4479次閱讀

    為什么要使用Redis做緩存?

    Java里提供了HashMap,Redis也有類似的數據結構,就是哈希類型。但是要注意,哈希類型的映射關系叫作field-value,注意這里的value是指field對應的值,不是鍵對應的值。
    的頭像 發表于 03-13 09:50 ?2389次閱讀

    如何從0到1構建一個穩定、高性能的Redis集群?

    這個架構非常簡單,你的業務應用可以把 Redis 當做緩存來使用,從 MySQL 查詢數據,然后寫入到 Redis ,之后業務應用再從 Redi
    的頭像 發表于 07-19 15:19 ?614次閱讀
    如何從0到1構建一個穩定、高性能的<b class='flag-5'>Redis</b>集群?

    Redis架構演化之路

    這個架構非常簡單,你的業務應用可以把 Redis 當做緩存來使用,從 MySQL 查詢數據,然后寫入到 Redis ,之后業務應用再從 Redi
    的頭像 發表于 08-03 16:54 ?592次閱讀
    <b class='flag-5'>Redis</b>架構演化之路

    redis查看主從節點命令

    Redis是一種開源的內存數據結構存儲系統,常被用作數據庫、緩存和消息中間件。在Redis,可以通過一些命令來查看主從節點的信息,以便進行監控和管理。 Redis 主從復制是指將一個
    的頭像 發表于 12-04 11:44 ?1233次閱讀

    redis hash底層實現原理

    Redis是一個開源的內存數據庫,使用鍵值對存儲數據。其中,Redis的數據結構之一就是哈希(Hash),它提供了一種將多個字段(Field)存儲在一個鍵(Key)的方法。那么
    的頭像 發表于 12-04 16:27 ?559次閱讀

    redis容器運行時間久了會自動執行flushdb

    Redis是一種開源的內存數據庫,常用于緩存、消息傳遞、持久化等場景。在Redis,flushdb命令用于清空當前數據庫的所有數據。然而,Red
    的頭像 發表于 12-05 10:12 ?898次閱讀