首頁 >資料庫 >Redis >redis原子操作有哪些

redis原子操作有哪些

anonymity
anonymity原創
2019-06-05 13:56:417577瀏覽

Redis是一個開源的使用ANSI C語言編寫、支援網路、可基於記憶體亦可持久化的日誌型、Key-Value資料庫,並提供多種語言的API。

redis原子操作有哪些

原子性

原子性是資料庫的事務中的特性。在資料庫事務的情境下,原子性指的是:一個事務(transaction)中的所有操作,要麼全部完成,要麼全部不完成,不會結束在中間某個環節。

對於Redis而言,命令的原子性指的是:一個操作的不可以再分,操作要麼執行,要麼不執行。

Redis操作原子性的原因

Redis的操作之所以是原子性的,是因為Redis是單執行緒的。

由於對作業系統相關的知識不是很熟悉,從上面這句話並不能真正理解Redis操作是原子性的原因,進一步查閱進程與執行緒的概念及其區別。

Redis在並發中的表現

Redis的API是原子性的操作,那麼多個指令在並發中也是原子性的嗎?

對Redis來說,執行get、set以及eval等API,都是一個一個的任務,這些任務都會由Redis的線程去負責執行,任務要么執行成功,要么執行失敗,這就是Redis的命令是原子性的原因。

Redis本身提供的所有API都是原子操作,Redis中的事務其實是要確保批次操作的原子性。

以上是redis原子操作有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn