原子性:

原子性是資料庫的事務中的特性。在資料庫事務的情景下,原子性指的是:一個事務(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中的事務其實是要保證批量操作的原子性。


推薦閱讀:
相關文章