首頁  >  文章  >  資料庫  >  redis中如何保證原子性

redis中如何保證原子性

尚
原創
2019-06-29 11:26:426991瀏覽

redis中如何保證原子性

原子性:

原子性是資料庫的事務中的特性。在資料庫事務的情境下,原子性指的是:一個事務(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中文網其他相關文章!

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