Redis异常记录
1、使用Redis集群时遇到“peer”异常,这通常意味着在集群中的某个节点出现了问题。Redis集群是分布式数据存储,它通过将数据分布在多个节点上以提高性能和可靠性。当一个节点无法正常工作,它可能会影响集群的稳定性和数据一致性。
2、根据百度经验查询得知,获取token异常通常是由于服务器没有正确响应token验证引起的。
3、如连接异常,应抛出异常,这样可以让代码更加健壮和完善。连接Redis时会出现各种异常,例如连接超时、连接被拒绝等,如不抛出异常,程序就无法知道Redis连接是否正常,也无法及时处理连接异常,会导致程序出现无法预料的错误。
4、这个异常一般是你操作的数据类型不正常,比如你在redis中key为“aaa”的value是一个list,这个时候你用key为“aaa”的键去存或取一个字符串的value就会报这个异常。
redis分布式锁常见问题及解决方案
使用redis客户端redisson,redisson很好的解决了redis在分布式环境下的一些棘手问题,它的宗旨就是让使用者减少对Redis的关注,将更多精力用在处理业务逻辑上。
锁的释放问题:多个客户端竞争同一把锁时,会出现一个客户端释放了锁,但别的客户端并没有释放的情况。这会导致别的客户端无法获取到锁,从而无法继续执行后续的操作。
问题-1 如果setnx执行成功,但是在expire执行的时候redis节点宕机了,在这种情况下,锁不会被释放,导致死锁。
Q & A环节。Codis是一个分布式Redis解决方案,与官方的纯P2P的模式不同,Codis采用的是Proxy-based的方案。今天我们介绍一下Codis及下一个大版本RebornDB的设计,同时会介绍一些Codis在实际应用场景中的tips。
释放锁的时候,只需要删除 del key 这个 key 就行了。
解决redis连接超时
在连接移动云云数据库Redis时,如果出现固定时间超时,可能是因为一些中间件设置了超时时间,比如nginx、haproxy等,才导致应用在固定时间不连接Redis后,连接被中间件主动断开。
所以导致的结果就是,可能你设置的超时时间是10s,但是真实执行的时间是超时12s后客户端才被关闭。CLIENT 命令Redis 的 CLIENT 命令能够实现三种功能:检查连接的状态,杀掉某个连接以及为连接设置名字。
服务器上的连接把IP改成本地IP:10.1试试看。
可以通过配置spring.session.store-type=none,关闭存储redis.这时候热key访问量下降,业务key 可以正常访问。通过以上方式,排查生产中遇到的redis 连接问题,可以排查线上遇到的问题,基本都可以解决掉。
除了timeout也还可以通过keepalive配置来解决,比如如果你的redis角色是sentinel,那么redis里的timeout的配置是不生效的。
关于Redis长连接的坑和redis经常性连接超时的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。