redis c->buf=3的极限测试,redis的解决方法

本文深入探讨了Redis中遇到的命令不完整问题,即所谓的shortread现象,并详细解析了Redis对此问题的解决方案。通过源码分析,文章揭示了Redis在处理命令不完整时的具体逻辑,包括如何避免错误命令导致的客户端关闭,以及如何确保querybuf数据的正确管理和使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

几天前做的redis c->buf=3极限测试,开始以为redis的解决方法就是把REDIS_REPLY_CHUNK_BYTES的数值放大。可是经过几天思考觉得不对,就算块放的再大也会出现命令不完整的情况,这种情况在redis中叫作short read。

查看源码后发现redis对这个问题的解决方法是:如果发现命令不完整就跳出读取命令的函数,同时不删除querybuf中的数据。直到命令完整时,才会删除querybuf中的数据。

但是他在判断的时候也注意到了错误命令的情况,如果出错误的命令,则异步关闭客户端。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值