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

你了解Redis事務(wù)嗎

 更新時(shí)間:2022年08月01日 11:42:44   作者:劍圣無(wú)痕  
說(shuō)到事務(wù),大家會(huì)立刻想到Mysql的事務(wù),所謂的事務(wù)就是對(duì)數(shù)據(jù)進(jìn)行一系列的操作,要么都執(zhí)行成功,要么都執(zhí)行失敗,下面就介紹一下Redis如何實(shí)現(xiàn)事務(wù),感興趣的可以了解一下

前言

說(shuō)到事務(wù),大家會(huì)立刻想到Mysql的事務(wù),所謂的事務(wù)就是對(duì)數(shù)據(jù)進(jìn)行一系列的操作,要么都執(zhí)行成功,要么都執(zhí)行失敗,事務(wù)提供了原子性(Atomicity)、一致性(Consistency)、隔離性(Isolation)、持久性(Durability),簡(jiǎn)稱ACID。這些屬性既包括了對(duì)事務(wù)執(zhí)行結(jié)果的要求,也有對(duì)數(shù)據(jù)庫(kù)在事務(wù)執(zhí)行前后的數(shù)據(jù)狀態(tài)變化的要求。那么Redis的事務(wù)能支持ACID嗎?

ACID屬性說(shuō)明

原子性(Atomicity)

事務(wù)中的全部操作在數(shù)據(jù)庫(kù)中是不可分割的,要么全部完成,要么全部不執(zhí)行。

一致性(Consistency)

事務(wù)的執(zhí)行使數(shù)據(jù)從一個(gè)狀態(tài)轉(zhuǎn)換為另一個(gè)狀態(tài),在事務(wù)開(kāi)始之前和事務(wù)結(jié)束之后,數(shù)據(jù)庫(kù)的完整性約束沒(méi)有被破壞。

隔離性(Isolation)

事務(wù)的隔離性要求每個(gè)讀寫事務(wù)的對(duì)象對(duì)其他事務(wù)的操作對(duì)象相互分離,即該事務(wù)提交前對(duì)其他事務(wù)都不可見(jiàn)。

持久性(Durability)

數(shù)據(jù)庫(kù)執(zhí)行事務(wù)后,數(shù)據(jù)的修改要被持久化保存下來(lái)。當(dāng)數(shù)據(jù)庫(kù)重啟后,數(shù)據(jù)的值需要是被修改后的值。

Redis如何實(shí)現(xiàn)事務(wù)

實(shí)現(xiàn)原理

Redis事務(wù)的執(zhí)行包含了三個(gè)步驟,具體如下:

  • 客戶端使用MULTI命令顯式地開(kāi)啟一個(gè)事務(wù)。

  • 客戶端把事務(wù)中本身要執(zhí)行的具體操作(例如增刪改數(shù)據(jù))發(fā)送給服務(wù)器端。這些操作就是Redis 本身提供的數(shù)據(jù)讀寫命令,雖然這些命令被客戶端發(fā)送到了服務(wù)器端,但是Redis實(shí)例只是把這些命令暫存到一個(gè)命令隊(duì)列中,并不會(huì)立即執(zhí)行。

  • Redis執(zhí)行EXEC命令執(zhí)行事務(wù)提交,服務(wù)器端收到EXEC命令后,才會(huì)實(shí)際執(zhí)行命令隊(duì)列中的所有命令。

事務(wù)相關(guān)命令

  • MULTI :開(kāi)啟事務(wù)
  • EXEC:提交事務(wù),執(zhí)行命令隊(duì)列中所有的操作命令。
  • DISCARD:放棄一個(gè)事務(wù),清空命令隊(duì)列,但是無(wú)法支持事務(wù)的回滾。
  • WATCH:檢測(cè)一個(gè)或多個(gè)鍵的值在事務(wù)執(zhí)行的期間是否發(fā)生變化,如果發(fā)生變化,那么當(dāng)前事務(wù)放棄執(zhí)行。

Redis的事務(wù)如何支持ACID

Redis事務(wù)的支持原子性嗎?

  • 情況一:執(zhí)行事務(wù)在入隊(duì)時(shí)就報(bào)錯(cuò),那么Redis會(huì)放棄事務(wù)執(zhí)行,從而保證事務(wù)原子性。
  • 情況二:命令在入隊(duì)時(shí)沒(méi)報(bào)錯(cuò),但是實(shí)際執(zhí)行時(shí)卻報(bào)錯(cuò),無(wú)法保證事務(wù)原子性。

情況一示例說(shuō)明

127.0.0.1:6379> multi
OK
127.0.0.1:6379> set t1 v1
QUEUED
127.0.0.1:6379> set t2 v2
QUEUED
127.0.0.1:6379> setget t3
(error) ERR unknown command 'setget'
127.0.0.1:6379> set t4 v4
QUEUED
127.0.0.1:6379> exec
(error) EXECABORT Transaction discarded because of previous errors.
127.0.0.1:6379> get t4
(nil)

說(shuō)明:在執(zhí)行exec命令之前,如果發(fā)生語(yǔ)法錯(cuò)誤(使用了不存在的命令),那么命令入隊(duì)時(shí),Redis就會(huì)報(bào)錯(cuò)并且記錄錯(cuò)誤,等到執(zhí)行Exec命令之后,Redi會(huì)拒絕所有提交的命令,事務(wù)執(zhí)行失敗。這種情況Reids的事務(wù)是可以支持原子性。

情況二示例說(shuō)明

127.0.0.1:6379> multi 
OK
127.0.0.1:6379> incr s2
QUEUED
127.0.0.1:6379> set a1 v1
QUEUED
127.0.0.1:6379> set a2 v2
QUEUED
127.0.0.1:6379> exec
1) (error) ERR value is not an integer or out of range
2) OK
3) OK
127.0.0.1:6379> get a2
"v2"

說(shuō)明: s2的值為v2,當(dāng)執(zhí)行incr命令時(shí)報(bào)報(bào)錯(cuò),因?yàn)閕ncr只能新增integer的類型值,但是這種情況下我們發(fā)現(xiàn)Redis的事務(wù)沒(méi)有進(jìn)行回滾,后面的命令能夠執(zhí)行成功,所以這種情況下時(shí)無(wú)法保證事務(wù)的原子性。

Redis事務(wù)的支持一致性嗎?

情況一:命令入隊(duì)時(shí)就報(bào)錯(cuò)

針對(duì)第一種情況,事務(wù)本身就會(huì)被放棄執(zhí)行,所以可以保證事務(wù)的一致性。

情況二:命令入隊(duì)時(shí)沒(méi)報(bào)錯(cuò),實(shí)際執(zhí)行時(shí)報(bào)錯(cuò)

針對(duì)第二種情況,有錯(cuò)誤的命令不會(huì)被執(zhí)行,正確的命令可以正常執(zhí)行,也不會(huì)改變數(shù)據(jù)庫(kù)的一致性。

情況三:Exec執(zhí)行命令Redis實(shí)例發(fā)生故障

  • 如果Redis持久化設(shè)置為RDB,那么生成RDB快照不會(huì)在事務(wù)執(zhí)行時(shí)執(zhí)行,所以事務(wù)命令操作的結(jié)果不會(huì)被保存到RDB快照中,使用RDB快照進(jìn)行恢復(fù)時(shí),數(shù)據(jù)庫(kù)里的數(shù)據(jù)也是一致的。

  • 如果Reids持久化設(shè)置為AOF,而事務(wù)操作還沒(méi)有被記錄到AOF日志時(shí),實(shí)例就發(fā)生了故障,那么,使用AOF日志恢復(fù)的數(shù)據(jù)庫(kù)數(shù)據(jù)是一致的。如果只有部分操作被記錄到了AOF日志,我們可以使用 redis-check-aof 清除事務(wù)中已經(jīng)完成的操作,數(shù)據(jù)庫(kù)恢復(fù)后也是一致的。

Redis事務(wù)的支持隔離性嗎?

Redis實(shí)現(xiàn)事務(wù)的隔離性,需要通過(guò)watch命令來(lái)支持事務(wù)隔離性。Watch的原理是,在事務(wù)執(zhí)行前,監(jiān)控一個(gè)或者多個(gè)鍵的變化時(shí),當(dāng)事務(wù)調(diào)用EXEC命令執(zhí)行時(shí),WATCH機(jī)制會(huì)先檢查監(jiān)控的鍵是否被其它客戶端修改了。如果修改了監(jiān)聽(tīng)的值,就放棄事務(wù)執(zhí)行,避免事務(wù)的隔離性被破壞。

示例說(shuō)明

客戶端1:

127.0.0.1:6379> get blance
"100"
127.0.0.1:6379> watch blance
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> decrby blance 10
QUEUED
127.0.0.1:6379> incrby blance 10
QUEUED
127.0.0.1:6379> exec
(nil)

客戶端2:

127.0.0.1:6379> get blance
"100"
127.0.0.1:6379> set blance 90
OK
127.0.0.1:6379> get blance
"90"

說(shuō)明:客戶端1使用watch檢測(cè)balance,在開(kāi)啟事務(wù)后,在客戶端2執(zhí)行更改balance的值操作,模擬其他客戶端在事務(wù)執(zhí)行期間更改watch監(jiān)控的數(shù)據(jù),然后再執(zhí)行客戶端1的EXEC命令,發(fā)現(xiàn)事務(wù)未成功執(zhí)行。

Redis事務(wù)的支持持久性嗎?

Redis的事務(wù)無(wú)法支持持久性,如果Redis使用了RDB模式,一個(gè)事務(wù)執(zhí)行后,當(dāng)下一次的RDB快照還未執(zhí)行前,Redis發(fā)生了實(shí)例宕機(jī),那么這種情況下,事務(wù)修改的數(shù)據(jù)是無(wú)法保證持久化的,如果Redis采用AOF模式,如論持久化配置為no、everysec和always都可能會(huì)存在數(shù)據(jù)丟失,所以,不管 Redis采用那種持久化模式,事務(wù)的持久性都無(wú)法支持。

總結(jié)

本文對(duì)Redis的事務(wù)進(jìn)行詳細(xì)的講解,Redis對(duì)于事務(wù)的支持還是有限制的,所以大家在使用的過(guò)程中需要注意。

到此這篇關(guān)于你了解Redis事務(wù)嗎的文章就介紹到這了,更多相關(guān)Redis 事務(wù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 深入解析Java中Redis的20個(gè)常用方法

    深入解析Java中Redis的20個(gè)常用方法

    隨著互聯(lián)網(wǎng)技術(shù)的不斷發(fā)展,Java編程語(yǔ)言在計(jì)算機(jī)科學(xué)與技術(shù)中的應(yīng)用日益廣泛,本論文以"深入解析Java中Redis的20個(gè)常用方法"為主題,系統(tǒng)地探討了Java在Redis數(shù)據(jù)庫(kù)操作中的應(yīng)用和實(shí)現(xiàn),需要的朋友可以參考下
    2024-01-01
  • 如何在SpringBoot中使用Redis實(shí)現(xiàn)分布式鎖

    如何在SpringBoot中使用Redis實(shí)現(xiàn)分布式鎖

    這篇文章主要介紹了如何在SpringBoot中使用Redis實(shí)現(xiàn)分布式鎖,在實(shí)際開(kāi)發(fā)中有可能會(huì)遇到多個(gè)線程同時(shí)訪問(wèn)同一個(gè)共享變量,那么上鎖就很重要了,需要的朋友可以參考下
    2023-03-03
  • CentOS 6.6下Redis安裝配置記錄

    CentOS 6.6下Redis安裝配置記錄

    這篇文章主要介紹了CentOS 6.6下Redis安裝配置記錄,本文給出了安裝需要的支持環(huán)境、安裝redis、測(cè)試Redis、配置redis等步驟,需要的朋友可以參考下
    2015-03-03
  • 詳解Redis如何保證接口的冪等性

    詳解Redis如何保證接口的冪等性

    如何防止接口中同樣的數(shù)據(jù)提交,以及如何保證消息不被重復(fù)消費(fèi),這些都是shigen在學(xué)習(xí)的過(guò)程中遇到的問(wèn)題,今天,趁著在學(xué)習(xí)redis的間隙,我寫了一篇文章進(jìn)行簡(jiǎn)單的實(shí)現(xiàn),需要的朋友可以參考下
    2023-11-11
  • 大家都應(yīng)該知道的Redis過(guò)期鍵與過(guò)期策略

    大家都應(yīng)該知道的Redis過(guò)期鍵與過(guò)期策略

    這篇文章主要給大家介紹了一些應(yīng)該知道的Redis過(guò)期鍵與過(guò)期策略的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Redis具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • 詳解在Redis在Centos7上的安裝部署

    詳解在Redis在Centos7上的安裝部署

    Redis是一種高級(jí)key-value數(shù)據(jù)庫(kù)。這篇文章主要介紹了詳解在Redis在Centos7上的安裝部署,有興趣的可以了解一下。
    2016-12-12
  • Redis 對(duì)過(guò)期數(shù)據(jù)的處理方法

    Redis 對(duì)過(guò)期數(shù)據(jù)的處理方法

    這篇文章主要介紹了Redis 對(duì)過(guò)期數(shù)據(jù)的處理,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-10-10
  • 5分鐘教你docker安裝啟動(dòng)redis全教程(全新方式)

    5分鐘教你docker安裝啟動(dòng)redis全教程(全新方式)

    今天,我來(lái)帶大家使用一種全新的方式docker來(lái)安裝redis,首先我們來(lái)了解一下什么是redis以及我們?yōu)槭裁匆褂胷edis,以及它的優(yōu)缺點(diǎn),感興趣的朋友跟隨小編一起學(xué)習(xí)下吧
    2021-05-05
  • redis中使用java腳本實(shí)現(xiàn)分布式鎖

    redis中使用java腳本實(shí)現(xiàn)分布式鎖

    這篇文章主要介紹了redis中使用java腳本實(shí)現(xiàn)分布式鎖,本文同時(shí)講解了java腳本和lua腳本實(shí)現(xiàn)分布式鎖,需要的朋友可以參考下
    2015-01-01
  • Redis 搭建哨兵集群的操作步驟

    Redis 搭建哨兵集群的操作步驟

    在 主從架構(gòu)Redis搭建主從集群 中,一個(gè)slave節(jié)點(diǎn)掛了無(wú)影響,但是master節(jié)點(diǎn)掛了,就無(wú)法進(jìn)行寫操作了,影響高可用,Redis 提供了哨兵(Sentinel)機(jī)制來(lái)實(shí)現(xiàn)主從集群的自動(dòng)故障恢復(fù),本文給大家介紹了Redis 搭建哨兵集群的操作步驟,需要的朋友可以參考下
    2023-08-08

最新評(píng)論