十年網(wǎng)站開發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營(yíng)維護(hù)+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
小編給大家分享一下redis->eval()的優(yōu)勢(shì)有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)科技有限公司專業(yè)互聯(lián)網(wǎng)基礎(chǔ)服務(wù)商,為您提供成都機(jī)柜租用,高防服務(wù)器,成都IDC機(jī)房托管,成都主機(jī)托管等互聯(lián)網(wǎng)服務(wù)。
平時(shí)你用 Redis 是不是經(jīng)常 get()、set()一把梭?其實(shí) Redis 中還有很多有用的數(shù)據(jù)結(jié)構(gòu),以及各種方法。今天我們就來測(cè)試一下eval()方法。
Redis Eval 官方說明(節(jié)選)
EVAL script numkeys key [key ...] arg [arg ...]
從 Redis 2.6.0 版本開始,通過內(nèi)置的 Lua 解釋器,可以使用 EVAL 命令對(duì) Lua 腳本進(jìn)行求值。
Redis 使用單個(gè) Lua 解釋器去運(yùn)行所有腳本,并且, Redis 也保證腳本會(huì)以原子性(atomic)的方式執(zhí)行:當(dāng)某個(gè)腳本正在運(yùn)行的時(shí)候,不會(huì)有其他腳本或 Redis 命令被執(zhí)行。這和使用 MULTI / EXEC 包圍的事務(wù)很類似。在其他別的客戶端看來,腳本的效果(effect)要么是不可見的(not visible),要么就是已完成的(already completed)。
另一方面,這也意味著,執(zhí)行一個(gè)運(yùn)行緩慢的腳本并不是一個(gè)好主意。寫一個(gè)跑得很快很順溜的腳本并不難,因?yàn)槟_本的運(yùn)行開銷(overhead)非常少,但是當(dāng)你不得不使用一些跑得比較慢的腳本時(shí),請(qǐng)小心,因?yàn)楫?dāng)這些蝸牛腳本在慢吞吞地運(yùn)行的時(shí)候,其他客戶端會(huì)因?yàn)?a title="服務(wù)器" target="_blank" >服務(wù)器正忙而無法執(zhí)行命令。
實(shí)測(cè)
我的理解,Redis 中的 eval() 方法一般用于需要執(zhí)行多個(gè) redis 操作,來完成一個(gè)目標(biāo)的場(chǎng)景。
下面我模擬了一個(gè)操作 100 次 redis 的場(chǎng)景,當(dāng)然實(shí)際可能并不需要這么多,僅僅想讓大家看到差別。
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(<<