詳解redis腳本命令執(zhí)行問題(redis.call)
1、redis-cli命令行中執(zhí)行:
# 調(diào)用redis命令設(shè)置緩存
# 不傳參數(shù)
eval "return redis.call('set', 'name1', 'Tom')" 0
# 傳入1個(gè)值參數(shù)
eval "return redis.call('set', 'name2', ARGV[1])" 0 "Tom"
# 傳入1個(gè)鍵名參數(shù)和1個(gè)值參數(shù)
eval "return redis.call('set', KEYS[1], ARGV[1])" 1 "name3" "Tom"2、linux命令行中執(zhí)行:
# 指定lua腳本路徑,后面可跟上參數(shù),與redis-cli中不同,此處不需要指定KEYS的數(shù)量,但是需要用英文逗號(hào)隔開KEYS和ARGV參數(shù),逗號(hào)前后至少保留1個(gè)空格,否則報(bào)錯(cuò) redis-cli -a password --eval ./sadd_script.lua subjects , math redis-cli -a password --eval ./sadd_script.lua subjects , history

lua腳本中定義自己需要的業(yè)務(wù)代碼,demo:
local setName = KEYS[1]
local setValue = ARGV[1]
if string.len(setName) > 0 and string.len(setValue) > 0
then
return redis.call('sadd', setName, setValue)
else
return 0
end3、php代碼中執(zhí)行:
<?php
$redis = new Redis();
$redis->connect('192.168.1.201', 6379);
$redis->auth('123456');
$script = <<<EOF
return redis.call('lpush', KEYS[1], ARGV[1])
EOF;
$key1 = 'goods_list';
$value1 = mt_rand(10000, 99999);
//eval($script, $args = array(), $numKeys = 0),numKeys聲明args參數(shù)中KEYS數(shù)量,剩下的則都為ARGV參數(shù)
$res = $redis->eval($script, [$key1, $value1], 1);
var_dump($res);
到此這篇關(guān)于redis腳本命令執(zhí)行(redis.call)的文章就介紹到這了,更多相關(guān)redis腳本命令內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Redis優(yōu)雅地實(shí)現(xiàn)延遲隊(duì)列的方法分享
Redisson是Redis服務(wù)器上的分布式可伸縮Java數(shù)據(jù)結(jié)構(gòu),這篇文中主要為大家介紹了Redisson實(shí)現(xiàn)的優(yōu)雅的延遲隊(duì)列的方法,需要的可以參考一下2023-02-02
Redis鏈表底層實(shí)現(xiàn)及生產(chǎn)實(shí)戰(zhàn)
Redis 的 List 是一個(gè)雙向鏈表,鏈表中的每個(gè)節(jié)點(diǎn)都包含了一個(gè)字符串。是redis中最常用的數(shù)據(jù)結(jié)構(gòu)之一,本文主要介紹了Redis鏈表底層實(shí)現(xiàn)及生產(chǎn)實(shí)戰(zhàn),文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03
redis客戶端實(shí)現(xiàn)高可用讀寫分離的方式詳解
基于sentienl 獲取和動(dòng)態(tài)感知 master、slaves節(jié)點(diǎn)信息的變化,我們的讀寫分離客戶端就能具備高可用+動(dòng)態(tài)擴(kuò)容感知能力了,接下來通過本文給大家分享redis客戶端實(shí)現(xiàn)高可用讀寫分離的方式,感興趣的朋友一起看看吧2021-07-07
Redis實(shí)現(xiàn)分布式隊(duì)列淺析
Redis將數(shù)據(jù)存儲(chǔ)在內(nèi)存中,使得讀寫速度非??欤?jīng)常被用來做緩存系統(tǒng),這里我們將redis用來做一個(gè)分布式的消息隊(duì)列。這篇文章主要介紹了使用redis來作為消息隊(duì)列,并且進(jìn)行分布式主從配置,有需要的朋友可以參考借鑒,下面來一起看看吧。2016-11-11
windows環(huán)境下Redis+Spring緩存實(shí)例講解
這篇文章主要為大家詳細(xì)介紹了windows環(huán)境下Redis+Spring緩存實(shí)例教程,感興趣的小伙伴們可以參考一下2016-04-04
利用Redis實(shí)現(xiàn)防止接口重復(fù)提交功能
大家好,本篇文章主要講的是利用Redis實(shí)現(xiàn)防止接口重復(fù)提交功能,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12

