redis命令行执行lua脚本

1 篇文章 0 订阅
本文介绍了如何在Redis中利用lua脚本确保多条命令的原子执行,包括EVAL、EVALSHA、SCRIPTLOAD、SCRIPTEXISTS等关键命令及其用法示例,以及SCRIPTFLUSH和SCRIPTKILL的脚本管理功能。
摘要由CSDN通过智能技术生成


大家都知道:在Redis中执行的每条命令都能保证其原子性,但是如何保证多条原生命令执行的原子性呢?这时候Redis为这样的用户场景提供了 lua 脚本支持,用户可以向服务器发送 lua 脚本来执行自定义动作,获取脚本的响应数据。Redis 服务器会单线程原子性执行 lua 脚本,保证 lua 脚本在处理的过程中不会被任意其它请求打断。


  1. 常用命令

    1.1 EVAL script numkeys key [key ...] arg [arg ...]  

          numkeys 是key的个数,后边接着写key1 key2...  val1 val2....,示例:

    127.0.0.1:6379> eval "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 2 key1 key2 val1 val2
    1) "key1"
    2) "key2"
    3) "val1"
    4) "val2"

    1.2 SCRIPT LOAD script
          把脚本加载到脚本缓存中,返回SHA1校验值。但不会立马执行,示例:

    127.0.0.1:6379> SCRIPT LOAD "return 'hello world'"
    "5332031c6b470dc5a0dd9b4bf2030dea6d65de91"

    1.3 EVALSHA sha1 numkeys key [key ...] arg [arg ...] 
          根据sha1值执行脚本内容,示例:
     

    127.0.0.1:6379> SCRIPT LOAD "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 
    "a42059b356c875f0717db19a51f6aaca9ae659ea"
    127.0.0.1:6379> EVALSHA "a42059b356c875f0717db19a51f6aaca9ae659ea" 2 key1 key2 val1 val2
    1) "key1"
    2) "key2"
    3) "val1"
    4) "val2"

    1.4 SCRIPT EXISTS sha1 [sha1 ...] 
          根据sha1校验值判断脚本是否在缓存中,示例:

    127.0.0.1:6379> SCRIPT LOAD "return 'hello world'"
    "5332031c6b470dc5a0dd9b4bf2030dea6d65de91"
    127.0.0.1:6379> SCRIPT EXISTS 5332031c6b470dc5a0dd9b4bf2030dea6d65de91
    1) (integer) 1

    1.5  SCRIPT FLUSH
           清除Redis服务端所有 Lua 脚本缓存,示例:

    127.0.0.1:6379> script flush
    OK

    1.6 SCRIPT KILL 
          杀死目前正在运行的脚本

  2. 执行lua脚本 

    命令: redis-cli -a 密码 --eval Lua脚本路径 key [key …] , arg [arg …] 
    注意:英文逗号前后必须要要有个空格,否则执行会报错
    示例:

    root@hub2-8:/home# redis-cli -a xxxxx--eval demo.lua key1 key2 , val1 val2
    (nil)

     

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值