自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

如何在Redis中執(zhí)行Lua腳本?

數(shù)據(jù)庫(kù) Redis
Redis調(diào)用Lua腳本,腳本執(zhí)行完成后將結(jié)果返回給Redis,Redis再將結(jié)果返回給客戶(hù)端。這個(gè)過(guò)程中會(huì)出現(xiàn)Redis執(zhí)行結(jié)果類(lèi)型到Lua數(shù)據(jù)類(lèi)型的轉(zhuǎn)換,然后Lua類(lèi)型到Redis類(lèi)型的轉(zhuǎn)換。

Redis中需要執(zhí)行Lua腳本的場(chǎng)景

Redis中每條命令都是原子性的,即執(zhí)行結(jié)果要么全部成功要么全部失敗。在某些業(yè)務(wù)場(chǎng)景下,需要執(zhí)行多條命令,并且要保證多條命令的原子性。這時(shí),如果命令逐條執(zhí)行,顯然是不能保證原子性的。有同學(xué)可能會(huì)想到使用Redis的事務(wù)功能,事務(wù)是可以保證原子性,但是受限于命令的功能,有些場(chǎng)景下并不能實(shí)現(xiàn)想要的功能。

使用執(zhí)行Lua腳本的方式可以解決以上問(wèn)題,Lua腳本整體上在Redis中是原子性的。

在Redis中執(zhí)行Lua腳本

在Redis中通過(guò)EVAL命令來(lái)執(zhí)行Lua腳本,基本語(yǔ)法如下:

redis 127.0.0.1:6379> EVAL script numkeys key [key ...] arg [arg ...]

參數(shù)說(shuō)明:

  • script: 參數(shù)是一段Lua腳本程序。腳本不必(也不應(yīng)該)定義為一個(gè) Lua 函數(shù)。
  • numkeys: 用于指定鍵名參數(shù)的個(gè)數(shù)。
  • key [key ...]: 從 EVAL 的第三個(gè)參數(shù)開(kāi)始算起,表示在腳本中所用到的那些 Redis 鍵(key),這些鍵名參數(shù)可以在 Lua 中通過(guò)全局變量 KEYS 數(shù)組,用 1 為基址的形式訪(fǎng)問(wèn)( KEYS[1] , KEYS[2] ,以此類(lèi)推)。
  • arg [arg ...]: 附加參數(shù),在 Lua 中通過(guò)全局變量 ARGV 數(shù)組訪(fǎng)問(wèn),訪(fǎng)問(wèn)的形式和 KEYS 變量類(lèi)似( ARGV[1] 、 ARGV[2] ,諸如此類(lèi))。

獲取指定key的值,相當(dāng)于于 GET somekey

EVAL "return redis.call('GET', KEYS[1])" 1 somekey

再看一個(gè)LPUSH的例子,相當(dāng)于 LPUSH somelist 1 2 3

EVAL "return redis.call('LPUSH',KEYS[1], ARGV[1], ARGV[2], ARGV[3])" 1 somelist 1 2 3

簡(jiǎn)單說(shuō)下Redis執(zhí)行l(wèi)ua腳本相關(guān)的其他幾個(gè)命令:

  • EVALSHA命令根據(jù)給定的SHA1,執(zhí)行緩存在服務(wù)器中的腳本。
  • SCRIPT EXISTS命令用于檢查指定SHA1值對(duì)應(yīng)的腳本是否在Redis緩存中。
  • SCRIPT FLUSH命令用于清除所有的緩存腳本。
  • SCRIPT KILL命令用于殺死當(dāng)前正在運(yùn)行的 Lua 腳本,當(dāng)且僅當(dāng)這個(gè)腳本沒(méi)有執(zhí)行過(guò)任何寫(xiě)操作時(shí),這個(gè)命令才生效。這個(gè)命令主要用于終止運(yùn)行時(shí)間過(guò)長(zhǎng)的腳本,比如一個(gè)因?yàn)?BUG 而發(fā)生無(wú)限循環(huán)的腳本。SCRIPT KILL 執(zhí)行之后,當(dāng)前正在運(yùn)行的腳本會(huì)被殺死,執(zhí)行這個(gè)腳本的客戶(hù)端會(huì)從 EVAL 命令的阻塞當(dāng)中退出,并收到一個(gè)錯(cuò)誤作為返回值。

Lua腳本中調(diào)用Reids命令

調(diào)用Redis命令,當(dāng)執(zhí)行出錯(cuò)時(shí),該方法會(huì)直接返回錯(cuò)誤,并退出。

redis.call(redisCommand, key, argv...)

調(diào)用Redis命令,當(dāng)執(zhí)行出錯(cuò)時(shí),記錄錯(cuò)誤信息,并繼續(xù)執(zhí)行。

redis.pcall(redisCommand, key, argv...)

記錄日志,寫(xiě)入到Redis配置的日志文件中,日志級(jí)別有四種,分別是redis.LOG_DEBUG、redis.LOG_VERBOS、redis.LOG_NOTICE和redis.LOG_WARNING。

redis.log(logLevel, message)

計(jì)算輸入字符串的sha1哈希值。

redis.sha1hex(arvg)

Lua與Redis類(lèi)型轉(zhuǎn)換

Redis調(diào)用Lua腳本,腳本執(zhí)行完成后將結(jié)果返回給Redis,Redis再將結(jié)果返回給客戶(hù)端。這個(gè)過(guò)程中會(huì)出現(xiàn)Redis執(zhí)行結(jié)果類(lèi)型到Lua數(shù)據(jù)類(lèi)型的轉(zhuǎn)換,然后Lua類(lèi)型到Redis類(lèi)型的轉(zhuǎn)換。Redis類(lèi)型到Lua類(lèi)型轉(zhuǎn)換關(guān)系如下:

Redis返回的數(shù)據(jù)類(lèi)型

Lua數(shù)據(jù)類(lèi)型

integer(整數(shù)回復(fù))

number(數(shù)字類(lèi)型)

bulk replay(字符串)

string(字符串類(lèi)型)

多行字符串

table(數(shù)組形式)

status(狀態(tài)回復(fù))

table(只有一個(gè)ok字段的數(shù)組)

error(錯(cuò)誤回復(fù))

table(只有一個(gè)err字段的數(shù)組)

Lua類(lèi)型到Redis類(lèi)型轉(zhuǎn)換關(guān)系如下:

Lua數(shù)據(jù)類(lèi)型

Redis返回?cái)?shù)據(jù)類(lèi)型

number(數(shù)字類(lèi)型)

integer(整數(shù)回復(fù))

string(字符串類(lèi)型)

bulk replay(字符串)

table(數(shù)組形式)

多行字符串

table(只有一個(gè)ok字段的數(shù)組)

status(狀態(tài)回復(fù))

table(只有一個(gè)err字段的數(shù)組)

error(錯(cuò)誤回復(fù))

責(zé)任編輯:姜華 來(lái)源: 今日頭條
相關(guān)推薦

2011-08-23 09:56:52

UnicodeLua

2016-12-20 09:30:22

shell腳本linux

2011-08-25 13:22:40

CEGUILua腳本

2011-08-25 09:55:27

2009-06-08 21:35:02

Java啟動(dòng)程序

2017-04-13 10:46:14

Webpack執(zhí)行代碼分割

2017-01-18 20:38:36

LinuxShell腳本命令

2011-08-24 10:32:03

LuaPlusC++Lua

2021-08-20 10:46:25

Shell腳本文件Linux

2021-04-21 08:03:34

腳本Shell讀取

2021-01-18 17:23:30

代碼調(diào)試VS Code

2023-10-19 14:52:27

2024-05-31 12:54:37

.NET CoreLinux語(yǔ)言

2019-08-06 14:06:19

數(shù)據(jù)庫(kù)工具技術(shù)

2025-02-28 08:21:36

C語(yǔ)言C++Java

2022-03-08 07:22:48

Redis腳本分布式鎖

2021-11-26 00:04:01

RedisLua 腳本

2011-08-31 15:36:59

Lua解釋器

2017-03-10 10:37:16

Linux命令腳本

2020-06-04 17:00:37

Linux命令腳本
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)