服务器的丢包率高怎么办

网络出现丢包状况了怎么办,具体情况可以从以下几点来判断:

1.有可能是线路故障导致的,所以可以用光纤打光仪先判断是否是光纤的问题。

2.对于设备方面来说,很多都是网络接口的光纤接触不良等。

3.也可能是操作系统的问题,比如网卡问题和网络运营线路问题,可以尝试使用ping命令测试。

什么是丢包

数据在Internet上是以数据包为单位传输的,单位是字节,数据在网络上传输,受网络设备,网络质量等原因的影响,使得接收到的数据少于发送出去的数据,造成丢包。

如果是硬件丢包,可以查看eth0网卡Ring Buffer最大值和当前设置

sql 复制代码
$ethtool -g eth0

解决方案:修改网卡eth0接收与发送硬件缓存区大小

sql 复制代码
$ethtool -G eth0 rx 4096 tx 4096

1.查看网卡丢包统计:ethtool -S eth1/eth0

2.查看网卡配置状态:ethtool eth1/eth0

如果是网卡流控丢包

1.查看流控统计:

sql 复制代码
ethtool -S eth1 | grep control

2.查看网络流控配置:ethtool -a eth1

解决方案:关闭网卡流控

sql 复制代码
ethtool -A ethx autoneg off //自协商关闭
ethtool -A ethx tx off //发送模块关闭
ethtool -A ethx rx off //接收模块关闭

网线接触不良:

如果网卡统计里面存在crc error计数增长,很可能是网线接触不良:

sql 复制代码
ethtool -S eth0

解决方案:一般试着重新插拔一下网线,或者换一根。

如果是网卡驱动丢包

sql 复制代码
ifconfig eth1/eth0

1.RX errors: 表示总的收包的错误数量,还包括too-long-frames错误,Ring Buffer 溢出错误,crc 校验错误,帧同步错误,fifo overruns 以及 missed pkg 等等。

2.RX dropped: 表示数据包已经进入了 Ring Buffer,但是由于内存不够等系统原因,导致在拷贝到内存的过程中被丢弃。

3.RX overruns: 表示了 fifo 的 overruns,这是由于 Ring Buffer(aka Driver Queue) 传输的 IO 大于 kernel 能够处理的 IO 导致的,而 Ring Buffer 则是指在发起 IRQ 请求之前的那块 buffer。很明显,overruns 的增大意味着数据包没到 Ring Buffer 就被网卡物理层给丢弃了,而 CPU 无法即使的处理中断是造成 Ring Buffer 满的原因之一,上面那台有问题的机器就是因为 interruprs 分布的不均匀(都压在 core0),没有做 affinity 而造成的丢包。

  1. RX frame: 表示 misaligned 的 frames。

  2. 对于 TX 的来说,出现上述 counter 增大的原因主要包括 aborted transmission, errors due to carrirer, fifo error, heartbeat erros 以及 windown error,而 collisions 则表示由于 CSMA/CD 造成的传输中断。

相关推荐
阿巴~阿巴~2 分钟前
线程安全单例模式与懒汉线程池的实现与优化
linux·服务器·单例模式·线程池·饿汉模式·懒汉模式·静态方法
大隐隐于野5 分钟前
tcp 丢包分析
linux·服务器·网络
梦昼初DawnDream30 分钟前
linux安全基线
linux·运维·安全
Broken Arrows31 分钟前
在Linux系统中,top命令的显示参数详解
linux·运维·服务器
APIshop44 分钟前
PHP:一种强大的服务器端脚本语言
服务器·php
code-vibe3 小时前
物理机 kali 改造笔记 (一)
linux·运维·服务器
小坏讲微服务3 小时前
五分钟使用 Docker-compose搭建 Redis 8.0 中间件
运维·redis·docker·中间件·容器·kubernetes·k8s
老黄编程3 小时前
03-gpg(证书管理 )详细范例
linux·运维·ubuntu·数字证书
Aimyon_364 小时前
MinerU Docker自定义版本部署
运维·docker·容器
莱茶荼菜4 小时前
Ubuntu 20.04 系统库管理详细教程
linux·运维·ubuntu