詳解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 end
3、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)容請(qǐng)搜索腳本之家以前的文章或繼續(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-02Redis鏈表底層實(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-03redis客戶端實(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)秒殺功能的簡(jiǎn)單方法
這篇文章主要給大家介紹了關(guān)于使用Redis實(shí)現(xiàn)秒殺功能的簡(jiǎn)單方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05Redis實(shí)現(xiàn)分布式隊(duì)列淺析
Redis將數(shù)據(jù)存儲(chǔ)在內(nèi)存中,使得讀寫速度非???,經(jīng)常被用來做緩存系統(tǒng),這里我們將redis用來做一個(gè)分布式的消息隊(duì)列。這篇文章主要介紹了使用redis來作為消息隊(duì)列,并且進(jìn)行分布式主從配置,有需要的朋友可以參考借鑒,下面來一起看看吧。2016-11-11windows環(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é)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12Redis中秒殺場(chǎng)景下超時(shí)與超賣問題的解決方案
當(dāng)我們?cè)趌inux中使用ab來模擬高并發(fā)秒殺時(shí)可能會(huì)遇到兩種問題,“超時(shí)和超賣”,本文就詳細(xì)介紹了Redis中秒殺場(chǎng)景下超時(shí)與超賣問題的解決方案,感興趣的可以了解一下2022-05-05