Linux计算TCP重传率 shell脚本分享!
为什么需要重传
任何信息在介质中传输可能丢失,这是由于传输介质的物理特性决定的,所以网络不可能被设计为“可靠的”(不是由于考虑“性能”原因而是压根做不到)。既然物理层无法提供可靠数据传输那么只能由协议提供可靠传输了,其中最有名的协议就是TCP了。
TCP是基于IP的网络协议,它提供可靠、有序的数据传输。在数据传输之前客户端和服务器端通过三次握手建立连接,建立连接的就是双方交换Seq(数据包序号)、MSS(每个TCP数据包大小) 、Win(滑动窗口,一次可以确认多少个TCP数据包),连接建立完成后每个TCP数据包都要被ACK(确认)。简单来说TCP通过确认/重传机制实现了“数据包可靠传输”。
TCP重传率高的监控
TCP重传率是对网络质量的一个体现,简单包装netstat -s的输出可以计算出TCP重传率。分享下之前检查的脚本如下:
#!/bin/bash export PATH='/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin' SHELLDIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" netstat -s -t > /tmp/netstat_s 2>/dev/null s_r=`cat /tmp/netstat_s | grep 'segments send out' | awk '{print $1}'` s_re=`cat /tmp/netstat_s | grep 'segments retransmited' | awk '{print $1}'` [ -e ${SHELLDIR}/s_r ] || touch ${SHELLDIR}/s_r [ -e ${SHELLDIR}/s_re ] || touch ${SHELLDIR}/s_re l_s_r=`cat ${SHELLDIR}/s_r` l_s_re=`cat ${SHELLDIR}/s_re` echo $s_r > ${SHELLDIR}/s_r echo $s_re > ${SHELLDIR}/s_re tcp_re_rate=`echo "$s_r $s_re $l_s_r $l_s_re" | awk '{printf("%.2f",($2-$4)/($1-$3)*100)}'` echo $tcp_re_rate
TCP重传率高的可能原因
发生重传说明网络传输有丢包,基本上从3个点去定位:客户端网络情况、服务端网络情况、中间链路网络情况
- 客户端机器网络异常
- 服务端网卡流量跑满,网卡有丢包现象,关注ifconfig的error输出
- 中间网络连路拥塞,比如交换机上联、核心交换机链路等,需要逐个排查链路流量情况
后期会分享更多运维DBA和devops内容,感兴趣朋友可以关注下!
相关推荐
tianhuak 2020-11-24
以梦为马不负韶华 2020-10-20
彼岸随笔 2020-10-20
yutou0 2020-10-17
applecarelte 2020-10-16
ourtimes 2020-10-16
jarrygao 2020-11-02
shipinsky 2020-09-23
touchfuture 2020-09-16
hongsheyoumo 2020-09-04
huha 2020-10-16
lianshaohua 2020-09-23
laisean 2020-11-11
zhangjie 2020-11-11
大牛牛 2020-10-30
firefaith 2020-10-30
liguojia 2020-10-20
wangzhaotongalex 2020-10-20
CARBON 2020-10-20