https://www.jianshu.com/p/f456e73a0437

name

ethtool - query or control network driver and hardware settings

ethtool

with a single argument specifying the device name prints current settings of the specified device.

ethtool eno1
Settings for eno1:
Supported ports: [ ]
Supported link modes: 1000baseT/Full
Supported pause frame use: Symmetric
Supports auto-negotiation: Yes
Supported FEC modes: Not reported
Advertised link modes: 1000baseT/Full
Advertised pause frame use: No
Advertised auto-negotiation: Yes
Advertised FEC modes: Not reported
Speed: Unknown!
Duplex: Unknown! (255)
Port: Other
PHYAD: 0
Transceiver: internal
Auto-negotiation: off
Supports Wake-on: g
Wake-on: g
Current message level: 0x00000007 (7)
drv probe link
Link detected: no
# ethtool ens5f0
Settings for ens5f0:
Supported ports: [ FIBRE ]
Supported link modes: 1000baseKX/Full ##支持的链路模式
10000baseKR/Full
25000baseCR/Full
25000baseKR/Full
25000baseSR/Full
Supported pause frame use: Symmetric ##暂停帧的支持,以太网流量控制
Supports auto-negotiation: Yes ##链路自动协商
Supported FEC modes: None BaseR
Advertised link modes: 1000baseKX/Full
10000baseKR/Full
25000baseCR/Full
25000baseKR/Full
25000baseSR/Full
Advertised pause frame use: Symmetric
Advertised auto-negotiation: Yes ##建议自动协商
Advertised FEC modes: None ##建议的FEC mode
Speed: 10000Mb/s ##速率
Duplex: Full ##双工模式
Port: FIBRE ##port类型,,还会有
PHYAD: 0 ##网卡的物理标识,如果两个device的PHYAD相同,表示在一块物理网卡上
Transceiver: internal ##internal — Use internal transceiver、external — Use external transceiver.
Auto-negotiation: on
Supports Wake-on: d
Wake-on: d ##Wake On LAN是否启用,d:禁用,g:启用
Current message level: 0x00000004 (4)
link
Link detected: yes ##对于link也有一个比较实用的redhat kb:https://access.redhat.com/solutions/46885

--version

Shows the ethtool version number.

# ethtool --version
ethtool version 4.8

-a --show-pause

Queries the specified Ethernet device for pause parameter information.

[root@localhost ~]# ethtool -a eno1
Pause parameters for eno1:
Autonegotiate: off
RX: off
TX: off [root@localhost ~]# ethtool --show-pause eno1
Pause parameters for eno1:
Autonegotiate: off
RX: off
TX: off

当以太网卡不能处理对端发送的数据帧时,将发送‘PAUSE’帧到对端,请求暂停发送。
当本端以太网卡可处理更多数据时,或者‘PAUSE’请求的暂停时间超时,对端可继续发送数据。可使用以下的ethtool命令查看网卡的流控设置。

-g --show-ring

Queries the specified network device for rx/tx ring parameter information.

[root@localhost ~]# ethtool -g eno3
Ring parameters for eno3:
Pre-set maximums:
RX: 4096
RX Mini: 0
RX Jumbo: 0
TX: 4096
Current hardware settings:
RX: 512
RX Mini: 0
RX Jumbo: 0
TX: 512

ringbuffer
The network interface ("NIC") shares a data structure with the operating system kernel software in order to pass network packets between them. Usually there are separate structures for transmit and receive directions, and commonly the data structure employed is a logical ring of buffers. This results in the term "ring buffer" being often used to indicate this interface structure. Usually all the buffers in a ring are of the same size.

The kernel device driver for the NIC, and the NIC firmware or hardware, cooperate in managing the data structure.

ifconfig输出下的drop error 通常跟ringbuffer相关。
ens5f0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
ether 98:03:9b:48:c7:dc txqueuelen 1000 (Ethernet)
RX packets 2815480 bytes 236634030 (225.6 MiB)
RX errors 0 dropped 441 overruns 0 frame 0
TX packets 0 bytes 0 (0.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0

-G --set-ring

Changes the rx/tx ring parameters of the specified network device.
rx N Changes the number of ring entries for the Rx ring.
rx-mini N Changes the number of ring entries for the Rx Mini ring.
rx-jumbo N Changes the number of ring entries for the Rx Jumbo ring.
tx N Changes the number of ring entries for the Tx ring.

设置ringbuffer的大小
[root@localhost ~]# ethtool -G ens5f0 rx 2048
[root@localhost ~]# ethtool -g ens5f0
Ring parameters for ens5f0:
Pre-set maximums:
RX: 8192
RX Mini: 0
RX Jumbo: 0
TX: 8192
Current hardware settings:
RX: 2048
RX Mini: 0
RX Jumbo: 0
TX: 1024

ethtool -G 命令设置ringbuffer为临时生效
永久生效方法,可参考如下linux kb:https://access.redhat.com/solutions/2127401

-i --driver

Queries the specified network device for associated driver information.

查询网卡的driver以及微码版本
[root@localhost ~]# ethtool -i eno1
driver: i40e
version: 2.8.20-k
firmware-version: 5.10 0x80002c06 1.2890.0
expansion-rom-version:
bus-info: 0000:5b:00.2
supports-statistics: yes
supports-test: yes
supports-eeprom-access: yes
supports-register-dump: yes
supports-priv-flags: yes

--可以查看到网卡的driver信息
--可以查看到网卡的微码版本信息
--可以查看到网卡的总线信息,这个也是比较有用的,bus number结合lspci命令可以如下这样使用:
[root@localhost ~]# lspci -s 5b:00.2 -v
5b:00.2 Ethernet controller: Intel Corporation Ethernet Connection X722 for 1GbE (rev 09)
Subsystem: Lenovo Ethernet Connection X722 for 1GbE
Flags: bus master, fast devsel, latency 0, IRQ 32, NUMA node 0
Memory at 23ffb000000 (64-bit, prefetchable) [size=16M]
Memory at 23fff008000 (64-bit, prefetchable) [size=32K]
Expansion ROM at e3b80000 [disabled] [size=512K]
Capabilities: [40] Power Management version 3
Capabilities: [50] MSI: Enable- Count=1/1 Maskable+ 64bit+
Capabilities: [70] MSI-X: Enable+ Count=129 Masked-
Capabilities: [a0] Express Endpoint, MSI 00
Capabilities: [e0] Vital Product Data
Capabilities: [100] Advanced Error Reporting
Capabilities: [150] Alternative Routing-ID Interpretation (ARI)
Capabilities: [160] Single Root I/O Virtualization (SR-IOV)
Capabilities: [1a0] Transaction Processing Hints
Capabilities: [1b0] Access Control Services
Kernel driver in use: i40e
Kernel modules: i40e

-p --identify

Initiates adapter-specific action intended to enable an operator to easily identify the adapter by sight. Typically this involves blinking one or more LEDs on the specific network port.

小写的P,点亮网卡,用来定位网卡物理位置,命令执行后,ctrl+c 取消执行:
[root@localhost ~]# ethtool -p eno1
^C

-P --show-permaddr

Queries the specified network device for permanent hardware address.
大写的p,查看网卡的mac地址、ip ad和ifconfig等命令均可实现这种功能。

[root@localhost ~]# ethtool -P eno1
Permanent address: 08:94:ef:9c:13:ea
[root@localhost ~]# ip ad |grep -i eno1 -A 1
4: eno1: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc mq state DOWN group default qlen 1000
link/ether 08:94:ef:9c:13:ea brd ff:ff:ff:ff:ff:ff
[root@localhost ~]# ifconfig eno1
eno1: flags=4099<UP,BROADCAST,MULTICAST> mtu 1500
ether 08:94:ef:9c:13:ea txqueuelen 1000 (Ethernet)
RX packets 0 bytes 0 (0.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 0 bytes 0 (0.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0

-r --negotiate

Restarts auto-negotiation on the specified Ethernet device, if auto-negotiation is enabled.

[root@localhost ~]# ethtool -r eno3
[root@localhost ~]#

看下实际效果,系统会让网卡再重新协商一次链路,可以看到如下日志输出:
localhost kernel: i40e 0000:5b:00.0 eno3: NIC Link is Down
localhost kernel: i40e 0000:5b:00.0 eno3: NIC Link is Up, 10 Gbps Full Duplex, Flow Control: None
localhost NetworkManager[1886]: <info> [1670530932.4519] device (eno3): carrier: link connected

-S --statistics

Queries the specified network device for NIC- and driver-specific statistics.
这个命令输出信息会非常多,也是非常有用的:

[root@localhost ~]# ethtool -S eno3|more
NIC statistics:
rx_packets: 2330214 # Trasmitted packets
tx_packets: 63464 #Received packets
rx_bytes: 230354804
tx_bytes: 14182808
rx_errors: 0 #Trasmission errors
tx_errors: 0 #Received errors
rx_dropped: 0
tx_dropped: 0
collisions: 0
rx_length_errors: 0
rx_crc_errors: 0
rx_unicast: 34715
tx_unicast: 48219
rx_multicast: 11552
tx_multicast: 15241
rx_broadcast: 2283947
tx_broadcast: 4
rx_unknown_protocol: 0
tx_linearize: 0

--对于统计信息,一方面理解各个信息代表的含义是重要的,这方面mellanox有一个文档相对比较详细:https://support.mellanox.com/s/article/understanding-mlx5-ethtool-counters
--零一点对于排障比较重要的是,在排障过程中通常需要对计数器进行重置,redhat对此有一篇文档:
https://access.redhat.com/solutions/125793
--实际上ethtool -S 的计数信息对于排查IP层的丢包、物理层的丢包有着比较重要的意义,有一个思路是首先首先要判断丢包是发生在tcp/ip哪个层面,然后从ethtool -S的技术中查看丢包的原因。
--实际上ethtool -S 的计数信息对于排查IP层的丢包、物理层的丢包有着比较重要的意义,有一个思路是首先首先要判断丢包是发生在tcp/ip哪个层面,然后从ethtool -S的技术中查看丢包的原因。

-s --change

Allows changing some or all settings of the specified network device. All following options only apply if -s was specified.

speed N
Set speed in Mb/s. ethtool with just the device name as an argument will show you the supported device speeds.

duplex half|full
Sets full or half duplex mode.

port tp|aui|bnc|mii
Selects device port.

mdix auto|on|off
Selects MDI-X mode for port. May be used to override the automatic detection feature of most adapters. An argument of auto means automatic detection of MDI status, on
forces MDI-X (crossover) mode, while off means MDI (straight through) mode. The driver should guarantee that this command takes effect immediately, and if necessary
may reset the link to cause the change to take effect.

autoneg on|off
Specifies whether autonegotiation should be enabled. Autonegotiation is enabled by default, but in some network devices may have trouble with it, so you can disable it
if really necessary

--show-priv-flags

Queries the specified network device for its private flags. The names and meanings of private flags (if any) are defined by each network device driver.
--set-priv-flags
Sets the device's private flags as specified.
flag on|off Sets the state of the named private flag.
对网卡设置一些私有的标志,这些选项跟驱动强相关,意味着如果驱动版本低的话,则无法修改这些选项。
通常是在一些特定的场景下才会需要修改这些标志,如下一个案例:
https://access.redhat.com/solutions/4054441

--show-fec

Queries the specified network device for its support of Forward Error Correction.
一种前向错误纠正技术,旨在增强数据传输的可靠性。
Forward error correction (FEC) is an error correction technique to detect and correct a limited number of errors in transmitted data without the need for retransmission.

In this method, the sender sends a redundant error-correcting code along with the data frame. The receiver performs necessary checks based upon the additional redundant bits. If it finds that the data is free from errors, it executes error-correcting code that generates the actual frame. It then removes the redundant bits before passing the message to the upper layers.

谁提供的ethtool包?

通过如下命令进行查询
[root@localhost ~]# which ethtool
/usr/sbin/ethtool
[root@localhost ~]# rpm -qf /usr/sbin/ethtool
ethtool-4.8-10.el7.x86_64

[转帖]ethtool 命令介绍的更多相关文章

  1. [转帖]十二 个经典 Linux 进程管理命令介绍

    https://www.cnblogs.com/swordxia/p/4550825.html 接了 http referer 头 没法显示图片 可以去原始blog 里面去查看.   随笔- 109  ...

  2. 12个Linux进程管理命令介绍(转)

    12个Linux进程管理命令介绍 [日期:2015-06-02] 来源:Linux中国  作者:Linux [字体:大 中 小]   执行中的程序在称作进程.当程序以可执行文件存放在存储中,并且运行的 ...

  3. 2.SDK目录结构和adb工具及命令介绍

    安卓开发学习笔记 1.安卓开发之环境搭建 2.SDK目录结构和adb工具及命令介绍 1.SDK目录介绍: ******************************** add-ons:Androi ...

  4. git各种命令介绍以及碰到的各种坑

    一.各种命令介绍: git pull:从其他的版本库(既可以是远程的也可以是本地的)将代码更新到本地,例如:'git pull origin master'就是将origin这个版本库的代码更新到本地 ...

  5. tar.xz如何解压:linux和windows下tar.xz解压命令介绍

    在linux下怎么解压和压缩tar.xz文件? (本文由www.169it.com搜集整理) 在linux下解压tar.xz文件步骤 1 2 # xz -d ***.tar.xz  //先解压xz # ...

  6. 查看MySQL数据库表的命令介绍

    如果需要查看MySQL数据库中都有哪些MySQL数据库表,应该如何实现呢?下面就为您介绍查看MySQL数据库表的命令,供您参考. 进入MySQL Command line client下查看当前使用的 ...

  7. Docker学习总结之Run命令介绍

    Docker学习总结之Run命令介绍 本文由Vikings(http://www.cnblogs.com/vikings-blog/) 原创,转载请标明.谢谢! 在使用Docker时,执行最多的命令某 ...

  8. ethtool命令

    用途 显示或修改以太网卡的配置信息. 语法 ethtool [ -a | -c | -g | -i | -d | -k | -r | -S |] ethX ethtool [-A] ethX [aut ...

  9. maven常用命令介绍

    mvn 3.0.4 创建maven项目命令  mvn  archetype:generate   -DgroupId=damocles-autocredit -DartifactId=damocles ...

  10. 用ethtool 命令解决Linux 网卡丢包【转】

    转自:https://blog.csdn.net/chengxuyuanyonghu/article/details/73739516 生产中有一台Linux设备并发比较大,droped包比较多,尤其 ...

随机推荐

  1. Typora+Docsify快速入门

    Typora是什么? ​ Typora中文版是一款好用极简的跨平台Markdown编辑器,软件使用这款软件能够帮助用户轻松将文本转换到HTML,软件从底层向上设计,软件支持markdown的标准语法, ...

  2. 第3章-图形处理单元-3.2-GPU管线概览

    3.2 GPU管线概览 GPU实现了第2章中描述的概念:几何处理.光栅化和像素处理流水线阶段.这些阶段被分为几个具有不同程度的可配置性或可编程性的硬件阶段.图3.2显示了根据可编程或可配置程度对各个阶 ...

  3. BugBuilder: 高质量大规模缺陷库自动构建方法

    摘要:本文提出并开发了高质量大规模缺陷库全自动构建方法BugBuilder,自动从版本控制系统中的人为编写的补丁中提取完整且精准的缺陷修复补丁. 本文分享自华为云社区<BugBuilder: 高 ...

  4. JS的深浅复制,原来如此!

    摘要:之所以会出现深浅拷贝的问题,实质上是由于JS对基本类型和引用类型的处理不同. 本文分享自华为云社区<js的深浅复制,一看就明白>,作者: 鑫2020. 浅复制的意思 浅复制是仅仅对数 ...

  5. Solon2 开发之插件,一、插件

    Solon Plugin 是框架的核心接口,简称"插件".其本质是一个"生命周期"接口.它可让一个组件类参与程序的生命周期过程(这块看下:<应用启动过程与 ...

  6. 什么?你居然没有鸭鸭邮箱?@duck.com邮箱注册与使用

    @duck.com 是由专注于隐私的搜索引擎DuckDuckGo提供的面向所有人的匿名邮箱. 注册者可以设置一个自定义前缀,比如 one@duck.com,接着设置接收邮箱(如pete@gmail.c ...

  7. 【ToolChains】| CMake 技巧

    判断 CMake 编译环境 编译类型 CMAKE_BUILD_TYPE 可取值为:Debug, Release, RelWithDebInfo, MinSizeRel 等预设值 if (CMAKE_B ...

  8. 数据结构——AVL树

    AVL树是一种特殊的二叉查找树,其特征在于:对所有节点来说,其左子树和右子树间的高度差小于等于1.本文简要总结下AVL树的几种基本操作. 节点结构体定义 typedef struct Node_s { ...

  9. 【每日一题】12.Running Median (对顶堆)

    补题链接:Here 题意:动态的维护中位数的问题,依次读入一个整数,每当总个数为奇数时输出此时序列的中位数 使用对顶堆的在线做法. 为了实时找到中位数,我们可以建议两个二叉堆:一个小根堆.一个大根堆. ...

  10. AIO异步通信。BIO同步阻塞式IO, NIO同步非阻塞通信。

    IO 什么是IO? 它是指计算机与外部世界或者一个程序与计算机的其余部分的之间的接口.它对于任何计算机系统都非常关键,因而所有 I/O 的主体实际上是内置在操作系统中的.单独的程序一般是让系统为它们完 ...