Redis是一個開源的使用ANSI C語言編寫、支援網路、可基於記憶體亦可持久化的日誌型、Key-Value資料庫,並提供多種語言的API。
原子性
原子性是資料庫的事務中的特性。在資料庫事務的情境下,原子性指的是:一個事務(transaction)中的所有操作,要麼全部完成,要麼全部不完成,不會結束在中間某個環節。
對於Redis而言,命令的原子性指的是:一個操作的不可以再分,操作要麼執行,要麼不執行。
Redis操作原子性的原因
Redis的操作之所以是原子性的,是因為Redis是單執行緒的。
由於對作業系統相關的知識不是很熟悉,從上面這句話並不能真正理解Redis操作是原子性的原因,進一步查閱進程與執行緒的概念及其區別。
Redis在並發中的表現
Redis的API是原子性的操作,那麼多個指令在並發中也是原子性的嗎?
對Redis來說,執行get、set以及eval等API,都是一個一個的任務,這些任務都會由Redis的線程去負責執行,任務要么執行成功,要么執行失敗,這就是Redis的命令是原子性的原因。
Redis本身提供的所有API都是原子操作,Redis中的事務其實是要確保批次操作的原子性。
以上是redis原子操作有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!