原子性:
原子性是資料庫的事務中的特性。在資料庫事務的情境下,原子性指的是:一個事務(transaction)中的所有操作,要麼全部完成,要麼全部不完成,不會結束在中間某個環節。
對於Redis而言,命令的原子性指的是:一個操作的不可以再分,操作要麼執行,要麼不執行。
Redis操作原子性的原因:
Redis的操作之所以是原子性的,是因為Redis是單執行緒的。
Redis在並發中的表現:
Redis的API是原子性的操作,那麼多指令在並發中也是原子性的嗎?
有以下程式碼:
$redis= newRedis(); $redis->connect('127.0.0.1',6379); for($i= 0;$iget('val'); $num++; $redis->set('val',$num); usleep(10000); }
用兩個終端執行上面的程序,發現val的結果是小於2000的值,那麼可以知道,在程式中執行多個Redis指令並非是原子性的,這也和一般資料庫的表現是一樣的。
如果想在上面的程式中實現原子性,可以將get和set改成單命令操作,例如incr,或者使用Redis的事務,或者使用Redis Lua的方式實現。
對Redis來說,執行get、set以及eval等API,都是一個一個的任務,這些任務都會由Redis的執行緒去負責執行,任務要嘛執行成功,要嘛執行失敗,這就是Redis的命令是原子性的原因。
Redis本身提供的所有API都是原子操作,Redis中的事務其實是要保證批量操作的原子性
更多Redis相關知識,請訪問 Redis使用教學專欄!
以上是redis中如何保證原子性的詳細內容。更多資訊請關注PHP中文網其他相關文章!