搜尋

首頁  >  問答  >  主體

用通俗點的語句告訴我Redis的操作的原子性是什麼意思?

最近在官網的教程上看到Redis的許多操作都是原子性的。
實在不懂啥意思。

伊谢尔伦伊谢尔伦2762 天前511

全部回覆(3)我來回復

  • PHPz

    PHPz2017-04-24 09:12:21

    操作的原子性保證操作不可再分,要麼完整執行要麼完整不執行。

    作業系統原理要學原子性的。時間有點久可能說的不太準確,舉個跟Redis沒關係的普通例子。

    有個變數A=10,我要給它加5。那我的「加5」操作要分成幾個步驟:

    • 讀A
    • 讀的結果+5
    • 結果寫回A

    有另外一個人要給它加3,他不知道我也要操作A變量,他的「加3」操作要分為幾個步驟:

    • 讀A
    • 讀的結果+3
    • 結果寫回A

    如果我們的操作(「加3」和「加5」)不是原子性的,互相之間的指令會亂排,無法預料結果,可能他先完成了+3的回寫,我讀的時候已經是13,於是得到了+3再+5的正確結果。也有可能他還在+3的運算中沒有寫回,我剛好讀到了10,於是回寫的時候有可能是13也有可能是15。

    如果我們的操作是原子性的,就可以保證他在進行加3操作的步驟的時候我無法插入其中,在他完成操作後我才能開始進行我的操作,從而保證數據是可靠的。

    回覆
    0
  • PHPz

    PHPz2017-04-24 09:12:21

    跟資料庫事務差不多,一組操作,要嘛都成功,要嘛都不執行

    回覆
    0
  • PHPz

    PHPz2017-04-24 09:12:21

    要乾就乾完,不乾就全不乾

    回覆
    0
  • 取消回覆