首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【redis】05-redis 事务(Multi、exec、watch、Discard)

Redis事务操作 Multi 开启事务 EXEC 提交事务 Watch 可以监听一个或者多个key,在提交事务之前是否有发生了变化 如果发生边了变化就不会提交事务,没有发生变化才可以提交事务 版本号码...乐观锁 Discard 取消提交事务 我们先来看一下multi和exec的效果 ?...运行流程: 线程A和线程B同一时间开启事务 由于线程A执行了两步操作,线程B只执行了一步操作 所以线程B先提交了事务,然后A再提交事务 此时redis中的值为线程A设置的zhangsan 根据上面的分析...,感觉这怎么和mysql中的事务不太对呢,都不能保证数据的一致性。...此时我们的redis官方为了解决这个问题,所以添加了watch命令。 ?

67420
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    redis中Lua 脚本,使用示例

    Redis中的Lua脚本示例下面是一些常见的Redis中的Lua脚本示例:示例1:计算缓存命中率下面的示例演示了如何使用Lua脚本计算缓存命中率::local hits = redis.call('GET...示例2:实现分布式锁下面的示例演示了如何使用Lua脚本实现分布式锁:local key = KEYS[1]local token = ARGV[1]local ttl = ARGV[2]local result...示例3:实现高级的消息队列下面的示例演示了如何使用Lua脚本实现高级的消息队列:local queue = KEYS[1]local data = ARGV[1]local priority = ARGV...[2]redis.call("ZADD", queue, priority, data)return true在上面的示例中,我们使用ZADD命令将数据添加到有序集合中,根据数据的优先级排序。...使用Lua脚本实现高级的消息队列可以帮助我们快速实现消息排序、去重、重试等功能。

    75910

    Redis中的事务与Lua脚本

    本文涉及:Redis中普通事务的实现方式、lua脚本的基础使用以及与Java的结合使用 普通事务 Redis本身提供了multi关键字用来开启事务,exec用来关闭事务。...·Lua脚本在Redis中是原子执行的,执行过程中间不会插入其他命令 ·Lua脚本可以帮助开发和运维人员创造出自己定制的命令,并可以将这些命令常驻在Redis内存中,实现复用的效果 ·Lua脚本可以将多条命令一次性打包...Redis与Lua脚本 1....在脚本中与redis进行交互: local value = redis.call('GET',key); redis.call('SET',key,value+2); redis.call('DECR'...Redis如何执行Lua脚本: redis-cli --eval redis-ratelimiter-counter.lua key limit , value1 value2 上方这段命令的意思呢,其实就是告诉

    2.3K50

    Redis Lua脚本调试

    您可以使用Redis unstable来调试稍后在稳定版本的Redis中运行的脚本,因此调试器已经可用于实际术语。...动态断点 使用该breakpoint命令可以将断点添加到特定行中。但是,有时我们只想在发生特殊情况时才停止执行程序。为此,您可以使用redis.breakpoint()Lua脚本中的 函数。...从脚本记录 该redis.debug()命令是一个功能强大的调试工具,可以在Redis Lua脚本中调用,以便将内容记录到调试控制台中: lua debugger> list -> 1 local...使用print和检查程序状态eval 虽然redis.debug()可以使用该函数直接从Lua脚本中打印值,但通常在步进或停止到断点时观察程序的局部变量很有用。...该print命令就是这样,并在调用帧中执行查找,从当前的一个回到之前的一个,直到顶层。这意味着即使我们进入Lua脚本中的嵌套函数,我们仍然可以使用print foo查看foo调用函数的上下文中的值。

    2.7K50

    Node.js 中实践 Redis Lua 脚本

    Lua 是一种轻量小巧的脚本语言,用标准 C 语言编写并以源代码形式开放,其设计目的是为了嵌入应用程序中,从而为应用程序提供灵活的扩展和定制功能。...Redis 的两种 Lua 脚本 Redis 支持两种运行 Lua 脚本的方式,一种是直接在 Redis 中输入 Lua 代码,适合于一些简单的脚本。...下面会分别介绍如何应用 Redis 提供的 EVAL、EVALSHA 两个命令来实现对 Lua 脚本的应用,同时介绍一些在 Node.js 中该如何去应用 Redis 的 Lua 脚本。...('SET', KEYS[1], ARGV[2])" 2 name1 name2 val1 val2 (nil) redis.call VS redis.pcall redis.call 和 redis.pcall...脚本文件 和上面 Node.js 中应用 Lua 差别不大,多了一步,通过 fs 模块先读取 Lua 脚本文件,在通过 eval 或者 evalsha 执行。

    4.5K31

    redis之初识lua脚本

    Lua脚本的另一个好处是它能够在保证原子性的同时,一次在脚本中执行多个Redis命令:对于需要在客户端和服务器之间往返通信多次的程序来说,使用Lua脚本可以有效地提升程序的执行效率。...因为Redis目前内置的是Lua 5.1版本的解释器,所以用户在脚本中也只能使用Lua 5.1版本的语法。...使用脚本执行Redis命令Lua脚本的强大之处在于它可以让用户直接在脚本中执行Redis命令,这一点可以通过在脚本中调用redis.call()函数或者redis.pcall()函数来完成:redis.call...为了解决上述问题,Redis提供了Lua脚本缓存功能,这一功能允许用户将给定的Lua脚本缓存在服务器中,然后根据Lua脚本的SHA1校验和直接调用脚本,从而避免了需要重复发送相同脚本的麻烦。...-> 1 redis.call('PING')lua debugger> 之后,调试器继续执行脚本,并在脚本的第5行停了下来,修改文件,将调用中的PONG修改为PING,然后再次在客户端中输入restart

    2.4K30

    Redis Lua脚本原理

    4 替换随机函数 5 创建排序辅助函数 6 创建redis.pcall函数 7 全局环境保护 8 修改后的Lua环境保存到服务器状态的Lua属性,等待脚本执行 Redis中带有不确定性的命令: SINTER...lua_scripts字典 保存Lua脚本的SHA1【校验和】checksum,值是对应的脚本。Redis会把EVAL命令执行过的脚本,或者SCRIPT LOAD加载的脚本都保存在字典中。 ?...字典的作用:实现SCRIPT EXISTS命令;实现脚本的复制 EVAL命令的实现 1 根据客户端给定的脚本,在Lua环境中定义Lua函数 2 将客户端给定的脚本保存到lua_scripts字段,进一步使用...3 执行刚刚在lua中定义的函数,执行客户端给定的lua脚本 通过函数保存传入的脚本好处: 1 执行方便 2 保持局部性 3 如果定义过一次,只要使用校验和即可。...0 脚本管理命令实现 SCRIPT FLUSH 用于清除服务器中lua有关的脚本,释放lua_scripts字典,关闭现有的lua环境,并重新创建 SCRIPT EXISTS 输入SHA1校验和,判断是否存在

    1.5K60

    Redis Lua脚本的使用

    中执行 Lua 脚本 Lua脚本功能为Redis开发和运维人员带来如下三个好处: Lua脚本在Redis中是原子执行的,执行过程中间不会插入其他命令。...Lua脚本可以帮助开发和运维人员创造出自己定制的命令,并可以将这些命令常驻在Redis内存中,实现复用的效果。 Lua脚本可以将多条命令一次性打包,有效地减少网络开销。...这和使用 MULTI / EXEC 包围的事务很类似。...当 Redis 执行 Lua 脚本时会对脚本进行检查,要执行的 lua 脚本: function fun() -- 业务逻辑 end 执行是报错,因为 Redis 不允许脚本中存在 function...使用脚本散发 Redis 日志 在 Lua 脚本中,可以通过调用 redis.log 函数来写 Redis 日志(log): redis.log(loglevel, message) 其中, message

    1.7K10

    Redis Lua脚本小学教程

    Redis怎么执行Lua脚本 EVAL命令 Redis中可以使用EVAL命令执行相应的Lua脚本 > EVAL 'local val="Hello Jackey" return val' 0 "Hello...在脚本中,可以理解为从KEYS数组和ARGV数组中获取对应的值,下标是从1开始的。...上面例子中的两个点是Lua脚本中字符串连接的操作符 现在我们已经知道怎么在Redis中执行Lua脚本了,可是这样的脚本和Redis没有关系啊,怎么才能操作Redis中的数据呢?...如果我们在Redis交互模式中,想要执行脚本文件怎么办?每次都退出来,执行完再连接一次?这未免太麻烦了。Redis提供了EVALSHA命令,使我们可以在交互模式执行脚本文件。...> EVALSHA 463ff2ca9e78e36cd66ee9d37ee0dcd59100bf46 1 my_name Hello "Hello Jackeyzhe" 终止脚本 Redis中Lua脚本到默认执行时长是

    1.1K40

    Redis Lua脚本大学教程

    前面我们已经把Redis Lua相关的基础都介绍过了,如果你可以编写一些简单的Lua脚本,恭喜你已经可以从Lua中学毕业了。...在大学课程中,我们主要学习Lua脚本调试和Redis中Lua执行原理两部分内容两部分。 Lua脚本调试 Redis从3.2版本开始支持Lua脚本调试,调试器的名字叫做LDB。...支持步进式执行 支持静态和动态断点 支持从脚本中向调试控制台打印调试日志 检查Lua变量 追踪Redis命令的执行 很好的支持打印Redis和Lua的值 无限循环和长执行检测,模拟断点 Lua脚本调试实战...执行完之后,还要删除钩子并把结果保存到缓冲中。 上面就是脚本执行的整个过程,这个过程之后,Redis还会处理一些脚本同步的问题。...这个前文我们也介绍过了《Redis Lua脚本中学教程(上)》 总结 到这里,Redis Lua脚本系列就全部结束了。文章虽然结束了,但是学习还远远没有结束。大家有问题的话欢迎和我一起探讨。

    1.1K20

    在Redis中实现脚本管理命令和复制Lua脚本

    图片Redis中实现脚本管理命令Redis中的脚本管理命令可以通过EVAL和EVALSHA来实现。EVAL命令用于执行Lua脚本,而EVALSHA命令则用于执行已经缓存的Lua脚本。...:执行已经缓存的Lua脚本。参数列表与EVAL命令相同,但是通过SHA1校验和引用脚本。使用以上命令,可以方便地管理和查看Redis中的Lua脚本。...Redis中实现复制Lua脚本在Redis中,复制Lua脚本是通过Replication功能来实现的。...当有新的Lua脚本被执行时,Redis会将这个Lua脚本的SHA1哈希值和相关的命令传播到所有的从节点上,并在每个从节点上执行该脚本。...如果客户端不支持复制,可能无法正确执行复制的Lua脚本。总结在Redis中复制Lua脚本是通过Replication功能来实现的。

    51561

    Redis系列之使用Lua脚本

    什么是lua脚本? lua语言是一个轻量级的脚本语言,可以嵌入其他语言中使用,调用宿主语言的功能。...lua语法简单,小巧,源码一共才200多K,本身不会有太强的功能,很多的语言也支持lua语言,比如redis、Nginx redis语言中完美嵌入了lua脚本功能,redis可以调用lua脚本中的api...,lua脚本也可以调用redis中的命令 redis调用lua脚本 在redis中调用lua脚本,需要使用eval指令 127.0.0.1:6379>eval "return 'hello'" 0 "hello...脚本调用redis命令 使用lua调用redis的命令,需要使用redis.call调用 # key为0表示能获取到锁 127.0.0.1:6379>eval "local key = redis.call...1 写个lua脚本,来实现一个简单的分布锁锁 private static final String LOCK_LUA_SCRIPT = "local lockParam = redis.call('exists

    57410

    Redis Lua脚本中学教程(上)

    在Lua中执行Redis命令的方法我们也介绍过,就是使用redis.call()和redis.pcall()两个函数。...脚本的原子性 Redis运行所有的Lua命令都使用相同的Lua解释器。当一个脚本正在执行时,其他的脚本或Redis命令都不能执行。这很像Redis的事务multi/exec。...值得一提的是,在Redis2.8.12之前,Lua脚本中执行SELECT是会影响到客户端的,而从2.8.12开始,Lua脚本中的SELECT只会在脚本执行过程中生效。...在脚本中打印Redis日志 使用redis.log(loglevel,message)函数可以在Lua脚本中打印Redis日志。...小结 本文介绍了Redis Lua相关的命令。其中EVAL和EVALSHA用来执行脚本。脚本执行具有原子性。脚本的复制和传播可以根据需要设置。脚本中不能定义全局变量。 客官!在看一下呗~

    85120

    Redis Lua脚本中学教程(下)

    在中学教程的上半部分我们介绍了Redis Lua相关的命令,没有看过或者忘记的同学可以步行前往直接使用机票Redis Lua脚本中学教程(上)。今天我们来简单学习一下Lua的语法。...全局变量 前面我们提到过Redis不支持Lua的全局变量,但Lua本身是支持全局变量的。 全局变量不需要声明,直接一个未初始化的变量时,它的值是nil。...例如: --[[A multi-line long comment ]] 不过通常我们使用另一种写法:以双横线加双左中括号开始,以双横线加双右中括号结束,这种写法看起来更加美观,同时解注释也更加方便:...Lua还提供了一种特殊的函数访问方法,有兴趣的话可以参考https://www.lua.org/pil/16.html o:foo(x) Lua程序中既可以使用定义在Lua中的函数,也可以使用定义在C...相信看完本文,你就可以写一些简单的Lua脚本了。 对Lua感兴趣的同学可以自行前往Lua官网(点击阅读原文跳转)继续深造。 客官!在看一下呗~

    95010

    主从架构&lua脚本-Redis(四)

    Slave收到文件则加载到内存,再接受缓存中的master数据。(此处rdb和配置的rdb持久化没关系) 如果master收到并发连接,只会持久化一次,把这一份数据发给所有slave。...三、Redis LUA脚本 1、减少网络开销。(多个命令一起发送,所以开销少) 2、原子性。 3、事务特性。...脚本意思是返回两个key和value,其中key1前面的2代表key的个数 那我们用lua脚本模拟如何实现事务的回滚以及原子性呢?...Lua脚本不会执行,则product_stock_10016为15 因为redis是单线程,前面也说了不能有大key,获取key不能用keys命令。...这里则不能再lua脚本出现死循环和耗时运算,因为他是单线程,如果因为lua脚本耗时太长甚至死循环,则整个redis会阻塞。

    18340
    领券