redis运维(十九)redis 的扩展应用 lua(一)

一  redis 的扩展应用 lua

redis如何保证原子操作

说明:引入'lua脚本',核心解决'原子性'问题

①  redis为什么引入lua?

lua脚本本身'体积小',启动'速度快'

redis运维(十九)redis 的扩展应用 lua(一)_第1张图片

redis运维(十九)redis 的扩展应用 lua(一)_第2张图片

②  redis引入lua的优势

小结: 类似'自定义redis命令'

redis运维(十九)redis 的扩展应用 lua(一)_第3张图片

redis运维(十九)redis 的扩展应用 lua(一)_第4张图片

③  redis中如何使用lua

redis运维(十九)redis 的扩展应用 lua(一)_第5张图片

④  EVAL

说明: '内置'的 lua解释器的版本是'5.1','避免'语法'兼容性'问题

注意: 从哪个版本redis引入'对lua'的支持

语法: EVAL script numkeys key [key ...] arg [arg ...]

细节: '多个lua语句'之间使用'分号'隔开

redis运维(十九)redis 的扩展应用 lua(一)_第6张图片

需求: 在'lua脚本'中获取redis'相关参数'

redis运维(十九)redis 的扩展应用 lua(一)_第7张图片

⑤  call和pcall函数

redis运维(十九)redis 的扩展应用 lua(一)_第8张图片

需求'1':查看call和pcall函数'报错'的'差异性'

需求'2':call'函数'的使用

redis运维(十九)redis 的扩展应用 lua(一)_第9张图片

补充:'()'是pcall函数的参数,里面的参数'类似'在redis-cli客户端中'执行命令','逗号变成空格'

redis运维(十九)redis 的扩展应用 lua(一)_第10张图片

⑥  lua和redis的数据转换

思考:'何时发生'数据类型转换?

redis使用的数据类型

redis运维(十九)redis 的扩展应用 lua(一)_第11张图片

--- 获取一个参数
local expire = ARGV[1]

--- 由于lua脚本接收到参数都会'转为String',如果要使用'数字'类型,必须'强转'
tonumber(expire)

⑦  lua类型redis类型

说明:eval命令的'返回值'的类型

强调:lua脚本的'return 返回值'被转换成'redis数据结构'

redis运维(十九)redis 的扩展应用 lua(一)_第12张图片

备注:redis数据类型和lua数据类型并'不完全'对应

redis运维(十九)redis 的扩展应用 lua(一)_第13张图片

备注: 希望lua返回一个'浮点数',那么应该将它作为一个'字符串',比如'ZSCORE'命令

⑧  redis数据结构转换为lua类型

1、lua通过'redis.call()'或者'redis.pcall()'函数执行redis命令

2、者两个函数调用'返回值'被转换成了'lua数据结构'

测试方法:首先在lua脚本中'执行redis命令',然后'type'下查看类型

redis运维(十九)redis 的扩展应用 lua(一)_第14张图片

你可能感兴趣的:(redis,redis,lua,eval,call,pcall)