找不到resources的静态资源文件
今天在做一人一单的过程中需要用到lua表达式存在resources但是找不到存放的lua文件,分析原因可能是build的过程中未导入文件
org.springframework.data.redis.core.script.ScriptingException: Error reading script text; nested exception is java.io.FileNotFoundException: class path resource [luaFile/unlock.lua] cannot be opened because it does not exist
解决
在maven的文件中添加
<build>
<resources>
<resource>
<directory>src/main/java</directory> <!-- .xml资源所在目录 -->
<includes> <!-- 包括目录下的 .xml 文件-->
<include>**/*.lua</include>
</includes>
<filtering>false</filtering> <!-- 暂时不需要管,加上就是了 -->
</resource>
</resources>
</build>
秒杀成功
优化工程中Redis没有相应的消费组
启动项目一直报错:NOGROUP No such key ‘stream.orders’ or consumer group ‘g1’ in XREADGROUP with GROUP option
原因:redis中没有stream.orders键
XGROUP CREATE stream.orders g1 0 MKSTREAM
# XGROUP CREATE 队列名称 组名称 起始id MKSTREAM不存在则自动创建
# XGROUP 支持创建和销毁组,也支持管理consumer
# XGROUP CREATE key groupname id|$ [MKSTREAM] [ENTRIESREAD entries_read]
# MKSTREAM 可选选项,默认不加的话,如果指定的 stream 不存在会返回错误,加上之后不存在则会自动创建 stream
下单业务明明有库存却报错error无库存
通过排查发现springboot无法从redis的Stream中获取属性,于是查看我们的lua脚本
redis.call('xadd', 'stream.orders', '*', 'userId', userId, 'voucherId', voucherId, 'id', orderId)
return 0
发现于vo类中的对应并不一致
修改一致
attempt to compare number with string
最近在一段项目代码里执行一个redis脚本,脚本的作用是获取一个list键中的元素个数,并与设定值(输入参数)比较,如果元素个数小于设定值则返回。测试时发现该脚本会报"attempt to compare number with string"错误,简化的脚本如下:
localhost:6379> eval “local key_len = redis.call(‘LLEN’, KEYS[1])
if key_len < ARGV[1] then return key_len end” 1 myKey 3
其中myKey就是要检测的list,设定的list长度为3。执行脚本后redis报错,说试图将数值与字符串相比较:
(error) ERR Error running script (call to f_a51f990b393ac7ebcc1132c458c355afbf8ccfa0):
user_script:1: attempt to compare number with string
脚本中只有一处比较运算,而且"LLEN myKey"命令的返回值肯定是整数,那么这就说明输入参数"ARGV[1]“是个字符串。实际上,不管你是想输入数值还是字符串,redis将所有的输入参数都设为了string类型。其实这也是高效的设计,因为只有程序员自己才知道自己设计脚本的目的,eval命令无法判断程序员到底是想输入数值3还是字符串"3”。所以,在执行与ARVG[1]的比较前,需要显式地调用Lua的"tonumber()"内建函数将ARGV[1]转化为number类型,脚本修改如下:
localhost:6379> eval “local key_len = redis.call(‘LLEN’, KEYS[1])
if key_len < tonumber(ARGV[1]) then return 0 end” 1 myKey 3
再次运行脚本执行正确。
Cause: java.sql.SQLException: Field ‘end_time’ doesn’t have a default value
; Field ‘end_time’ doesn’t have a default value; nested exception is java.sql.SQLException: Field ‘end_time’ doesn’t have a default value
结束时间没有默认值