linux ping排查发送数据超时问题

某天隔壁组同事反馈,他们的客户端连接我们的UniCenter发送数据的时候总是超时。流程:发送端A连接UniCenter(C的二进制程序),发送端通过UniCenter发送给另一个连接在UniCenter上的客户端。

首先,我们查看了系统的负载并不高
在这里插入图片描述
接着抓了多次的进程的堆栈,都能看到有很多发包的接口

在这里插入图片描述

使用netstat命令查看发现虽然sendq一直在变化,但是一直都会出现比较大的数字,查看模块自身支持的配置,放大接收端缓冲区大小以及增加自身线程数的配置,这些优化措施都加过了也生效了。
在这里插入图片描述
结合堆栈一起看,看上去像是发送端通过unicenter发送大数据包给其他模块,可能是数据比较大,发的有点慢,导致进程的固定回调线程都被占满了,全部都是send_packet,这个时候仍然有其他模块来通过unicenter发送数据导致返回超时,但是我们该做的优化措施都做了。

这个时候我们只能在看下网络延迟的情况,抽取几个sendq值较大的连接,ping了下,发现发送64bytes的数据,延迟最多达到了500ms,原来是这些机器和unicenter所在的机器之间延迟太大导致的超时。正常情况下只有几毫秒的延迟
在这里插入图片描述
在这里插入图片描述
抓包也验证了网络延迟高的问题
在这里插入图片描述
遂和现场沟通后,由客户方解决该问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值