网站首页 > 博客文章 正文
最近巡查项目线上日志时发现,Redis偶尔会抛出这种连接超时的异常,虽然只是短暂性的连接超时没有造成什么实质性的影响,但是本着尽职尽责的原则(其实是怕组长找上门 )还是查找了一番。
redis.clients.jedis.exceptions.JedisConnectionException: java.net.SocketTimeoutException: Read timed out
异常分析:
通过日志的详细分析发现,Redis是连接成功的,但是在执行某些命令的时候就会出现超时现象,并且是偶发性的
持续时间也不长。而Jedis默认设置的超时时常是2秒,而Redis执行命令时又是单线程的,那会不会哪个命令执行超过了2秒,导致阻塞了后面的命令执行呢?
通过 slowlog get 10 命令查看最近10条慢查询日志,发现keys这条命令执行时间超过了2秒,而经过测试发现在执行keys命令时确实会导致其他命令请求超时。
至此就找到了问题的所在了,keys命令执行时间超过了2秒导致其他命令阻塞。
keys命令为什么会慢:
1.时间复杂度
KEYS 命令的时间复杂度为 O(N),其中 N 是数据库中键的数量。这是因为 Redis 需要遍历整个数据库来查找匹配指定模式的键。当数据库中的键数量较少时,KEYS 命令的性能通常是可以接受的。
2.阻塞操作
由于 KEYS 命令需要遍历整个数据库,它会阻塞 Redis 服务器的其他操作。在执行 KEYS 命令期间,Redis 无法处理其他命令请求,这可能导致其他客户端的延迟增加。因此,在处理大型数据库或者在生产环境中,不推荐频繁使用 KEYS 命令。
3.内存消耗
KEYS 命令在执行期间需要将匹配的键保存在内存中。如果匹配的键较多或者键的值较大,KEYS 命令可能会消耗大量的内存。这可能导致 Redis 服务器的内存占用过高,并且可能触发 Redis 的内存淘汰机制(eviction),从而导致键被随机删除。
4.遍历时间
由于 KEYS 命令需要遍历整个数据库,它的执行时间与数据库中键的数量成正比。因此,如果数据库非常大,执行时间可能会很长。这可能会导致客户端请求超时或者导致 Redis 在一段时间内无法响应其他命令请求。
有什么命令可以代替keys:
根据官方给出的文档说明可以考使用SCAN 命令。SCAN 命令使用游标迭代方式逐步返回匹配的键,避免了一次性遍历整个数据库的性能问题。
猜你喜欢
- 2024-10-31 英雄联盟手游错误代码100008什么原因?LOL手游错误代码解决办法
- 2024-10-31 玩转网络自动化之ntc_templates模块
- 2024-10-31 C#程序与单片机通信时,如何自动初始化串口(2)?
- 2024-10-31 电机驱动_上位机_ModbusRTU通讯(伺服上位机)
- 2024-10-31 真实的线上故障处理案例(在线故障检测时应注意什么)
- 2024-10-31 问题反馈:为什么Cydia加载出现那么多红色错误?
- 2024-10-31 Norland诺兰德连接超时连接报错?一招解决连接问题
- 2024-10-31 处理超时订单(超时未付款)的解决方案
- 2024-10-31 第一后裔运行超时运行报错怎么办?一招解决运行问题
- 2024-10-31 基于 PTS 压测轻松玩转问题诊断(tps压测 指什么)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- powershellfor (55)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)