公司G美项目在线上运行过程中报错redisson Caused by: java.lang.StringIndexOutOfBoundsException: String index out of range: -167。
报错异常中有一行栈信息:
org.redisson.cluster.ClusterConnectionManager#calcSlot(java.lang.String) 691行
从信息中大致知道,是使用redisson的集群过程中,计算槽点(calcSlot)时报错。
找到该方法:
可以看到,异常出在对key进行截取时。
原来,在使用redis集群环境进行取锁时,redisson对于取槽点进行了处理:
默认是使用key进行计算。但是,当key中包含了花括号:{ 时,会认为用户需要使用花括号之间的字符数据作为取槽点的种子,进行槽点计算。
也就是说,花括号类似于redisson 的保留符号。如果要使用,必须是成对出现。
查看源数据key发现,客户在进行数据合并的时候,录入了左侧的花括号,却没有右侧的花括号(也许客户只是作为自己的某种约定或者数据的切割)。
既然知道了问题,那就好解决了。
比如:
1.禁止使用花括号(前提是花括号不是必须的);
2.在进行缓存槽点计算的时候,对key进行加工处理。
我们采用了第二种方法,因为在未知客户此符号的具体作用的情况下,产品应该自行解决。