Linux计算TCP重传率 shell脚本分享!

为什么需要重传

任何信息在介质中传输可能丢失,这是由于传输介质的物理特性决定的,所以网络不可能被设计为“可靠的”(不是由于考虑“性能”原因而是压根做不到)。既然物理层无法提供可靠数据传输那么只能由协议提供可靠传输了,其中最有名的协议就是TCP了。

TCP是基于IP的网络协议,它提供可靠、有序的数据传输。在数据传输之前客户端和服务器端通过三次握手建立连接,建立连接的就是双方交换Seq(数据包序号)、MSS(每个TCP数据包大小) 、Win(滑动窗口,一次可以确认多少个TCP数据包),连接建立完成后每个TCP数据包都要被ACK(确认)。简单来说TCP通过确认/重传机制实现了“数据包可靠传输”。

Linux计算TCP重传率 shell脚本分享!


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内容,感兴趣朋友可以关注下!

Linux计算TCP重传率 shell脚本分享!

相关推荐