redis 2.6.0版本开始,redis内置了Lua解释器,并提供了eval命令来解析Lua脚本求值。1. 语法格式语法: eval script numkeys keys args参数: eval — redis提供解析lua脚本的命令script — lua脚本numkeys — 指定键名参数集(keys)的个数keys — 键名参数集,通过全局变量KEYS数组表示,起始下标为1args
转载 2023-08-22 13:03:00
781阅读
redis学习笔记参考文档链接:https://pan.baidu.com/s/1sMUUYR3VGZcqPmJQNWeYDA 密码:hf2nredis脚本lua语言使用lua语言写一个脚本: local times = redis.call('incr', KEYS[1]) if times == 1 then -- keys[1]键刚创建吗所以为其设置生存时间
转载 2023-05-30 15:31:51
126阅读
1. ev={} 2. functin ev.__call() 3. print "called from ev" 4. end 5. 6. setmetatable(ev, ev) 7. 8. -- test it 9. ev()
转载 2016-11-11 15:13:00
195阅读
2评论
redis从2.6版本开始内置支持Lua解释器,解释器提供了3个函数来处理redis的命令redis.call() redis.pcall()和 redis.log,同时redis 也保证脚本会以原子性的方式执行。这是一个很重要的因素。本文涉及到的命令有 EVAL EVALSHA SCRIPT LOAD SCRIPT FLUSH
转载 2023-09-07 07:55:19
0阅读
在学习一门语言的时候,开始的时候就是不断熟悉其提供的API函数,只有熟悉了API函数的使用,才能在里面加入自己的思想,从而发挥作用达到自己的目的。今天学习的是lua_call,和该函数相似的函数分别是lua_pcall和lua_cpcall.这些函数的目的就是让我们能够执行压入栈中的函数,该函数可...
转载 2015-01-27 18:11:00
696阅读
2评论
lua_pcall和lua_call功能一样,只是lua_pcall提供了一个可以提供错误处理函数的功能首先压入函数 ,再依次压入参数,现在你就可以调用lua_call了,函数调用后将参数,函数都弹栈,函数返回时会将返回值依次压栈。调用前堆栈情况参数参数函数调用后堆栈情况返回值注意:无论在c函数里怎么调用栈,在pcall之后都会按函数的参数和返回值恢复栈
转载 2013-11-08 20:29:00
660阅读
2评论
RedisTemplate执行lua脚本在Redis集群模式下报错EvalSha is not supported in cluster environment.异常信息:org.springframework.dao.InvalidDataAccessApiUsageException: EvalSha is not supported in cluster environment. at o
转载 2023-06-27 23:58:48
411阅读
上节对Redis功能进行扩展,发布/订阅模式、事务相关内容。本节使用LuaRedis的功能进行扩展。Lua是一个轻3台机器,赶紧尝试在公网上搭建体验一下。
原创 2024-07-30 11:39:58
83阅读
需要完成功能借助redis Stream 数据结构实现消息队列,异步完成订单创建,其中涉及到了缓存(击穿,穿透,雪崩),锁(Redisson),并发处理,异步处理,Lua脚本IDE:IDEA 2022 1、读取库存数据 【Lua】  2、判断库存 【Lua】3、扣减库存 【Lua】4、创建队列和组 【Java】5、发送队列消息 
转载 2023-05-25 11:08:29
267阅读
目录一、Redis 基本命令 1. 测试Redis性能:redis-benchmark 2. Redis沟通命令,查看状态:ping 3.查看redis服务器的统计信息:info [section] 4.redis使用的数据库 5.查看当前数据库中 key 的数目:dbsize: 6.查看当前数据库中符合要求的 key: 7.判断 key 是否存在:exists key [key…]: 8.移动
转载 2024-05-29 06:43:34
36阅读
Redisson分布式锁的实现原理 加锁机制 如果该客户端面对的是一个 redis cluster 集群,他首先会根据 hash节点选择一台机器。发送 lua 脚本到 redis 服务器上,脚本如下 "if (redis.call('exists',KEYS[1])==0) then "+ --看有没有锁 "redis.call('hset',KEYS[1],A
转载 2023-10-08 16:44:40
137阅读
当master根据replica的PSYNC命令判断不能进行增量同步时,下面就需要进行全量同步。replica接受全量数据对于replica来说,会向事件循环中注册可读事件readSyncBulkPayload,用来接受从master传过来的全量数据:void syncWithMaster(aeEventLoop *el, int fd, void *privdata, int mask) {
转载 2024-01-28 06:17:50
35阅读
redis-2.6支持通过EVAL命令来执行lua脚本,对lua脚本的支持扩展了redis的应用场景,redis支持路脚本需要做2件事redis能执行lua脚本在lua脚本里能执行redis的命令接下来,我将通过一个简单的实例来解析redis如何完成上述两个工作的。 构建一个简单的redis#define DICT_SIZE 100 struct redisDict { char*
原创 2023-05-08 14:24:01
323阅读
序言这里主要讨论解决Redis Cluster集群环境下的高并发问题. 问题Redis的命令是串行执行的,但是在集群环境下命令的顺序是不能保证的,不同线程之间对同一个KEY的操作会有嵌套,造成数据不准确.如果是Redis服务器是不是集群,则可以使用Multi,Exec,Watch的命令组合来解决原子性问题.同时也可以根据业务情况独立一个Redis服务器,使用Multi,Exec,Watc
转载 2023-07-21 20:10:51
111阅读
一、问题描述 业务中出现需要保证原子性的一系列缓存操作,所以决定使用lua脚本来保证原子性。 但是调用过程中lua脚本抛出了异常:attempt to perform arithmetic on local ‘xxx’ (a nil value)
转载 2023-06-17 11:03:36
368阅读
1、安装lua类库环境               1.1、yum install -y readline              &nb
转载 2023-07-09 17:42:12
169阅读
客户端读写超时读写超时时间设置得过短命令本身就比较慢客户端与服务端网络不正常redis自身发生堵塞客户端连接超时连接超时时间设置过短redis发生阻塞,造成tcp-backlog 已满,造成新的连接失败客户端与服务端网络不正常客户端缓冲区异常输出缓冲区满,例如将普通客户端的输出缓冲区设置为1M 1M 60;config set client-output-buffer-limit "normal
转载 2023-08-15 17:30:17
100阅读
Lua脚本执行redis指令报错【java.lang.IllegalStateException】问题出现背景今天在学习redis时,为了让redis的多条指令(取锁、比锁、释放锁)保障原子性,我通过使用一个lua脚本统一去执行redis的的多条指令。在执行lua脚本时报错问题说明问题复现 这是我的lua脚本-- 获取锁的key,即: KEY_PREFIX + name local key = K
转载 2023-08-15 20:08:08
119阅读
为啥用redis呢(只是此处的使用原因):        因为redis是一个内存数据库,效率高;        redis支持事务;        redis
转载 2023-05-29 15:52:01
238阅读
为了保证数据的争用安全,通常要采用锁机制控制。如果是单应用部署,直接通过synchronized关键字修改方法,就能解决,但是如果是分布式的部署 该方法就不能解决这个问题啦,此时就引出了一个分布式锁的概念。常用的分布式锁的实现方式有三种:基于数据库乐观锁(CAS)来实现;基于 Redis 来实现;基于 ZooKeeper 来实现。本文介绍:基于 RedisLua 脚本实现分布式锁功能。一、为
转载 2023-09-03 13:19:11
127阅读
  • 1
  • 2
  • 3
  • 4
  • 5