真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Redis->eval()的優(yōu)勢有哪些

小編給大家分享一下redis->eval()的優(yōu)勢有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯(lián)科技有限公司專業(yè)互聯(lián)網(wǎng)基礎服務商,為您提供成都機柜租用,高防服務器,成都IDC機房托管,成都主機托管等互聯(lián)網(wǎng)服務。

平時你用 Redis 是不是經(jīng)常 get()、set()一把梭?其實 Redis 中還有很多有用的數(shù)據(jù)結構,以及各種方法。今天我們就來測試一下eval()方法。

Redis Eval 官方說明(節(jié)選)

EVAL script numkeys key [key ...] arg [arg ...]

從 Redis 2.6.0 版本開始,通過內(nèi)置的 Lua 解釋器,可以使用 EVAL 命令對 Lua 腳本進行求值。

Redis 使用單個 Lua 解釋器去運行所有腳本,并且, Redis 也保證腳本會以原子性(atomic)的方式執(zhí)行:當某個腳本正在運行的時候,不會有其他腳本或 Redis 命令被執(zhí)行。這和使用 MULTI / EXEC 包圍的事務很類似。在其他別的客戶端看來,腳本的效果(effect)要么是不可見的(not visible),要么就是已完成的(already completed)。

另一方面,這也意味著,執(zhí)行一個運行緩慢的腳本并不是一個好主意。寫一個跑得很快很順溜的腳本并不難,因為腳本的運行開銷(overhead)非常少,但是當你不得不使用一些跑得比較慢的腳本時,請小心,因為當這些蝸牛腳本在慢吞吞地運行的時候,其他客戶端會因為服務器正忙而無法執(zhí)行命令。

實測

我的理解,Redis 中的 eval() 方法一般用于需要執(zhí)行多個 redis 操作,來完成一個目標的場景。

下面我模擬了一個操作 100 次 redis 的場景,當然實際可能并不需要這么多,僅僅想讓大家看到差別。

connect('127.0.0.1', 6379);
 
// 清空Redis
$redis->flushDB();
 
// PHP 中循環(huán) set
$t = microtime(true);
for($i = 0; $i < 100; ++$i)
{
    $redis->set('key' . $i, $i);
}
echo 'php for set: ', microtime(true) - $t, PHP_EOL;
 
// 清空Redis
$redis->flushDB();
 
// 使用 eval 方法
$t = microtime(true);
$keys = [];
$values = [];
for($i = 0; $i < 100; ++$i)
{
    $keys[] = 'key' . $i;
    $values[] = $i;
}
$redis->eval(<<