Linux系统利用C语言获取网口信息(IP地址,MAC地址,状态,带宽speed等)

本文详细介绍了如何在Linux系统下利用ioctl接口获取网络接口的详细信息,包括网口状态、IP地址、MAC地址和带宽等。通过定义structifinfo结构体来存储网口信息,并提供了获取接口状态、IP地址和MAC地址的函数。代码示例展示了如何遍历所有网口并打印相关信息。测试结果显示,该程序在虚拟机中无法查询到网口的带宽信息,但在物理服务器上则可以获取正确的带宽数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

设计思路

ioctl操作参数

获取网口的遍历结构

获取对应的参数信息

源代码

ifinfo.c

ifinfo.h

test.c

测试结果


 

设计思路

首先给需要查询的信息定义个结构(当然,这里可以扩展)

/**
 *  struct ifinfo - 网卡信息结构
 *  
 *  if_idx  网口在系统中的索引,          这里需要注意的是,派生的网口 em1:1 与 em1 的索引相同
 *  if_name 网口名,例如:eth0
 *  if_flag 网口状态,参见 IFSTAT_XXX 宏定义
 *  if_ipv4 网口IP地址,例如:10.170.6.66
 *  if_eth.if_ethmac    网口MAC地址,格式:28:6E:D4:88:C7:9A
 *  if_eth.if_ethspeed  网口带宽,单位:Mbps
 */
struct ifinfo {
    unsigned int if_idx;    //接口索引号
    char if_name[32];       //接口名 如:eth0

    int if_flag;
#define IFSTAT_UP           0x0001  /* 接口状态为 up */
#define IFSTAT_BROADCAST    0x0002  /* 广播地址可用 */
#define IFSTAT_LOOPBACK     0x0004  /* 该网口是回环口 */
#define IFSTAT_POINTOPOINT  0x0010  /* 点对点连接 */
#define IFSTAT_MULTICAST    0x0020  /* 支持多播 */

    char if_ipv4[16];       //接口IPv4地址
    struct {
        char if_ethmac[64];         //MAC地址
        unsigned int if_ethspeed;   //速率 Mbps
    }if_eth;
};

ioctl操作参数

才头文件 sys/sockios.h,linux/sockios.h 中定义了一些列的操作数

#include <sys/sockios.h>
#include <linux/sockios.h>


#define SIOCGIFNAME	0x8910		/* get iface name		*/
#define SIOCSIFLINK	0x8911		/* set iface channel		*/
#define SIOCGIFCONF	0x8912		/* get iface list		*/
#define SIOCGIFFLAGS	0x8913		/* get flags			*/
#define SIOCSIFFLAGS	0x8914		/* set flags			*/
#define SIOCGIFADDR	0x8915		/* get PA address		*/
#define SIOCSIFADDR	0x8916		/* set PA address		*/
#define SIOCGIFDSTADDR	0x8917		/* get remote PA address	*/
#define SIOCSIFDSTADDR	0x8918		/* set remote PA address	*/
#define SIOCGIFBRDADDR	0x8919		/* get broadcast PA address	*/
#define SIOCSIFBRDADDR	0x891a		/* set broadcast PA address	*/
#define SIOCGIFNETMASK	0x891b		/* get network PA mask		*/
#define SIOCSIFNETMASK	0x891c		/* set network PA mask		*/

 

获取网口的遍历结构

使用ioctl接口的SIOCGIFCONF选项,

/* 获取所有网口的句柄信息 */
static int get_ifconf_r(int sockfd, struct ifconf *ifc, void *buf, int buf_len)
{
    if(sockfd <= 2 || !ifc || !buf || buf_len <= 0) {
        return -1;
    }

    ifc->ifc_len = buf_len;
    ifc->ifc_buf = buf;
    if (ioctl(sockfd, SIOCGIFCONF, ifc) == -1) {
        return -1;
    }
    return 0;
}

获取对应的参数信息

使用ioctl接口的SIOCGIFADDR选项,

/* 查询网口 IPv4 地址 */
static int get_ifaddr(int sockfd, const char *if_name, char *addr, int addr_len)
{
    if(sockfd <= 2 || !if_name || !addr || addr_len <= 0) {
        return -1;
    }
    struct ifreq ifr;
    
    strcpy(ifr.ifr_name, if_name);
    if (ioctl(sockfd, SIOCGIFFLAGS, &ifr) == 0) {
        if (ioctl(sockfd, SIOCGIFADDR, &ifr) == 0) {
            snprintf(addr,addr_len,"%s",
                        inet_ntoa(((struct sockaddr_in*)&(ifr.ifr_addr))->sin_addr));
        }
    }else{
        return -1;
    }
    return 0;
}

 

源代码

GitHub地址:https://github.com/Rtoax/test/tree/master/nic/ifinfo

ifinfo.c

/**
 *  获取网口信息,IP地址,MAC地址,状态,带宽等
 *  
 *  日期:2020年10月16日
 *  作者:RToax
 */
#include <unistd.h>
#include <string.h>
#include <stdio.h>
#include <netinet/in.h>
#include <net/if.h>
#include <sys/ioctl.h>
#include <arpa/inet.h>
#include <linux/sockios.h>
#include <linux/ethtool.h>

#include "ifinfo.h"

/* 创建Socket */
static int if_socket()
{
    int sock = socket(AF_INET, SOCK_DGRAM, IPPROTO_IP);
    if (sock == -1) {
        return -1;
    }
    return sock;
}

/* 获取所有网口的句柄信息 */
static int get_ifconf_r(int sockfd, struct ifconf *ifc, void *buf, int buf_len)
{
    if(sockfd <= 2 || !ifc || !buf || buf_len <= 0) {
        return -1;
    }

    ifc->ifc_len = buf_len;
    ifc->ifc_buf = buf;
    if (ioctl(sockfd, SIOCGIFCONF, ifc) == -1) {
        return -1;
    }
    return 0;
}

/* 获取网口状态 */
static int get_ifstat(int sockfd, const char *if_name, int *if_flag)
{
    if(sockfd <= 2 || !if_name || !if_flag) {
        return -1;
    }
    struct ifreq ifr;
    *if_flag = 0;
        
    strcpy(ifr.ifr_name, if_name);
    if (ioctl(sockfd, SIOCGIFFLAGS, &ifr) == 0) {
        if(ifr.ifr_flags & IFF_UP) *if_flag |= IFSTAT_UP;
        if(ifr.ifr_flags & IFF_BROADCAST) *if_flag |= IFSTAT_BROADCAST;
        if(ifr.ifr_flags & IFF_LOOPBACK) *if_flag |= IFSTAT_LOOPBACK;
        if(ifr.ifr_flags & IFF_POINTOPOINT) *if_flag |= IFSTAT_POINTOPOINT;
        if(ifr.ifr_flags & IFF_MULTICAST) *if_flag |= IFSTAT_MULTICAST;
    }else{
        return -1;
    }
    return 0;
}

/* 查询网口 IPv4 地址 */
static int get_ifaddr(int sockfd, const char *if_name, char *addr, int addr_len)
{
    if(sockfd <= 2 || !if_name || !addr || addr_len <= 0) {
        return -1;
    }
    struct ifreq ifr;
    
    strcpy(ifr.ifr_name, if_name);
    if (ioctl(sockfd, SIOCGIFFLAGS, &ifr) == 0) {
        if (ioctl(sockfd, SIOCGIFADDR, &ifr) == 0) {
            snprintf(addr,addr_len,"%s",
                        inet_ntoa(((struct sockaddr_in*)&(ifr.ifr_addr))->sin_addr));
        }
    }else{
        return -1;
    }
    return 0;
}

/* 查询网口 MAC 地址 */
static int get_ifhwaddr(int sockfd, const char *if_name, char *hwaddr, int hwaddr_len)
{
    if(sockfd <= 2 || !if_name || !hwaddr || hwaddr_len <= 0) {
        return -1;
    }
    struct ifreq ifr;
    
    strcpy(ifr.ifr_name, if_name);
    if (ioctl(sockfd, SIOCGIFHWADDR, &ifr) == 0) {
        unsigned char * ptr ;
        ptr = (unsigned char  *)&ifr.ifr_ifru.ifru_hwaddr.sa_data[0];
        snprintf(hwaddr,hwaddr_len,"%02X:%02X:%02X:%02X:%02X:%02X",
                        *ptr,*(ptr+1),*(ptr+2),*(ptr+3),*(ptr+4),*(ptr+5));
    }else{
        return -1;
    }
    return 0;
}

/* 查询网口带宽 */
static int get_ifethspeed(int sockfd, const char *if_name, unsigned int *speed)
{
    struct ifreq ifr;
    struct ethtool_cmd ep;
    
    strcpy(ifr.ifr_name, if_name);
    
    ep.cmd = ETHTOOL_GSET; 
    ifr.ifr_data = (caddr_t)&ep;  

    if (ioctl(sockfd, SIOCETHTOOL, &ifr) != 0) { // 如果出错退出; 
        return -1;
    }
    *speed = ep.speed;
    return 0;
}

/**
 *  get_ifinfo - 获取网口信息
 *
 *    该接口可以获取网口的速率,但是,在虚拟机环境中,无法查询网口带宽
 *  
 *  display_fn  查询的回调函数,参见: ifinfo_display 说明
 *  arg         回调函数被调用时的 arg 参数,该参数可以为 NULL
 *  
 *  return      失败,返回 -1, 成功,返回查询的网口总数
 */
int get_ifinfo(ifinfo_display display_fn, void *arg)
{
    /* 如果回调函数为空,则返回失败 */
    if(!display_fn) {
        return -1;
    }

    struct ifconf ifc;
    struct ifinfo info;
    
    char buf[2048];
    int ret = 0;    
    int count = 0;

    int sock = if_socket();/* 创建socket */
    
    ret = get_ifconf_r(sock, &ifc, buf, sizeof(buf));
    if(ret != 0) {
        close(sock);
        return -1;
    }

    /* 巧妙的网口结构保存 */
    struct ifreq* it = ifc.ifc_req;
    const struct ifreq* const end = it + (ifc.ifc_len / sizeof(struct ifreq));

    /* 轮询所有网口 */
    for (; it != end; ++it, count++) {
        memset(&info, 0, sizeof(struct ifinfo));
        
        strcpy(info.if_name, it->ifr_name);
        
        info.if_idx = if_nametoindex(info.if_name);

        /* 获取一系列的网口信息,当然可以在后面继续开发,
            但不要忘记在 struct ifinfo 添加对应的单数字段 */
        get_ifstat(sock, info.if_name, &info.if_flag);
        get_ifaddr(sock, info.if_name, info.if_ipv4, sizeof(info.if_ipv4));
        get_ifhwaddr(sock, info.if_name, info.if_eth.if_ethmac, sizeof(info.if_eth.if_ethmac));
        get_ifethspeed(sock, info.if_name, &info.if_eth.if_ethspeed);

        /* 在这里,回调函数将被调用 */
        if(display_fn) display_fn(&info, arg);
    }

    close(sock);

    return count;
}

ifinfo.h

/**
 *  获取网口信息,IP地址,MAC地址,状态,带宽等
 *  
 *  日期:2020年10月16日
 *  作者:RToax
 */
#ifndef __IF_INFO_H
#define __IF_INFO_H 1


/**
 *  struct ifinfo - 网卡信息结构
 *  
 *  if_idx  网口在系统中的索引,          这里需要注意的是,派生的网口 em1:1 与 em1 的索引相同
 *  if_name 网口名,例如:eth0
 *  if_flag 网口状态,参见 IFSTAT_XXX 宏定义
 *  if_ipv4 网口IP地址,例如:10.170.6.66
 *  if_eth.if_ethmac    网口MAC地址,格式:28:6E:D4:88:C7:9A
 *  if_eth.if_ethspeed  网口带宽,单位:Mbps
 */
struct ifinfo {
    unsigned int if_idx;    //接口索引号
    char if_name[32];       //接口名 如:eth0

    int if_flag;
#define IFSTAT_UP           0x0001  /* 接口状态为 up */
#define IFSTAT_BROADCAST    0x0002  /* 广播地址可用 */
#define IFSTAT_LOOPBACK     0x0004  /* 该网口是回环口 */
#define IFSTAT_POINTOPOINT  0x0010  /* 点对点连接 */
#define IFSTAT_MULTICAST    0x0020  /* 支持多播 */

    char if_ipv4[16];       //接口IPv4地址
    struct {
        char if_ethmac[64];         //MAC地址
        unsigned int if_ethspeed;   //速率 Mbps
    }if_eth;
};

/**
 *  ifinfo_display - 网口状态查询回调函数
 *  
 *  info    网口信息结构指针,参见: struct ifinfo 说明
 *  arg     调用 get_ifinfo 内存地址传入的 arg 地址指针
 */
typedef void (*ifinfo_display)(const struct ifinfo *info, void *arg);


/**
 *  get_ifinfo - 获取网口信息
 *
 *    该接口可以获取网口的速率,但是,在虚拟机环境中,无法查询网口带宽
 *
 *  display_fn  查询的回调函数,参见: ifinfo_display 说明
 *  arg         回调函数被调用时的 arg 参数,该参数可以为 NULL
 *  
 *  return      失败,返回 -1, 成功,返回查询的网口总数
 */
int get_ifinfo(ifinfo_display display_fn, void *arg);


#endif /*<__IF_INFO_H>*/

test.c


#include <stdio.h>

#include "ifinfo.h"


void ifdisplay(const struct ifinfo *info, void *arg)
{
    printf("%2d: %-10s %16s %18s %d Mb \n",
            info->if_idx, info->if_name,info->if_ipv4, info->if_eth.if_ethmac,info->if_eth.if_ethspeed);
}


int main()
{
    int ret = 0;
    while(1) {
        ret = get_ifinfo(ifdisplay, NULL);
        printf("Total %d interface.\n", ret);
        sleep(1);
    }
}

 

测试结果

在虚拟机中无法查询网口带宽

[root@localhost ifinfo]# make 
gcc ifinfo.c test.c -o test.out
[root@localhost ifinfo]# ./test.out 
 1: lo                127.0.0.1  00:00:00:00:00:00 0 Mb 
 2: eth0            10.170.6.66  28:6E:D4:88:C7:9A 0 Mb 
 5: docker0          172.17.0.1  02:42:57:6F:10:40 0 Mb 
Total 3 interface.

用ifconfig查询的结果
-----------------------------------
[root@localhost ifinfo]# ifconfig -a
docker0: flags=4099<UP,BROADCAST,MULTICAST>  mtu 1500
        inet 172.17.0.1  netmask 255.255.0.0  broadcast 172.17.255.255
        ether 02:42:57:6f:10:40  txqueuelen 0  (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

eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 10.170.6.66  netmask 255.255.255.0  broadcast 10.170.6.255
        inet6 fe80::2731:24c7:9924:2028  prefixlen 64  scopeid 0x20<link>
        inet6 fe80::4b76:dca0:14ca:2d95  prefixlen 64  scopeid 0x20<link>
        inet6 fe80::cb30:c5c4:34dd:895f  prefixlen 64  scopeid 0x20<link>
        ether 28:6e:d4:88:c7:9a  txqueuelen 1000  (Ethernet)
        RX packets 3347634794  bytes 2727102880807 (2.4 TiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 43937802  bytes 187858063132 (174.9 GiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10<host>
        loop  txqueuelen 1000  (Local Loopback)
        RX packets 888190  bytes 13054543624 (12.1 GiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 888190  bytes 13054543624 (12.1 GiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

这里介绍一个工具《Linux查看网口带宽状态(ifconfig,netstat,ethtool)》,该工具的:github地址

[root@localhost ifstatus]# ./ifstatus.sh 
	Name 	Speed  	Status  
	docker0 	Unknown! 	down
	eth0 	Unknown! 	up
	lo 	Unknown! 	up

在真实的物理服务器上运行结果为

[root@localhost rtoax]# ./test.out 
 1: lo                127.0.0.1  00:00:00:00:00:00 0 Mb 
 2: em1            10.170.7.166  20:04:0F:FA:87:3C 1000 Mb 
 2: em1:1          10.170.7.183  20:04:0F:FA:87:3C 1000 Mb 
 2: em1:2          10.170.7.184  20:04:0F:FA:87:3C 1000 Mb 
 2: em1:3          10.170.7.185  20:04:0F:FA:87:3C 1000 Mb 
 2: em1:4          10.170.7.186  20:04:0F:FA:87:3C 1000 Mb 
 2: em1:5          10.170.7.187  20:04:0F:FA:87:3C 1000 Mb 
 2: em1:6          10.170.7.188  20:04:0F:FA:87:3C 1000 Mb 
 2: em1:7          10.170.7.189  20:04:0F:FA:87:3C 1000 Mb 
 2: em1:8          10.170.7.190  20:04:0F:FA:87:3C 1000 Mb 
 2: em1:9          10.170.7.191  20:04:0F:FA:87:3C 1000 Mb 
 2: em1:10         10.170.7.192  20:04:0F:FA:87:3C 1000 Mb 
 3: em2            10.171.7.166  20:04:0F:FA:87:3D 65535 Mb 
 7: virbr0        192.168.122.1  52:54:00:9F:56:64 0 Mb 
Total 14 interface.

 

<think>嗯,用户问的是如何编写应用程序来测试嵌入式Linux开发板的网口。我需要先理清楚这个问题涉及的关键点。首先,测试网口通常包括哪些方面呢?可能包括网络接口的基本功能测试,比如连通性、带宽、丢包率,还有更底层的比如MAC和PHY层的测试,以及协议兼容性等。 接下来,用户可能是在进行嵌入式开发,需要确保硬件和驱动程序的正常工作。他们可能已经完成了硬件连接,现在需要编写测试程序来验证网口的性能。这时候,我需要考虑不同的测试方法,比如使用现有的工具还是自己编写应用程序。 首先,使用现有的工具可能更高效,比如用ping测试连通性,iperf3测试带宽,netcat进行数据传输测试。这些工具已经存在,用户可能只需要写一个脚本来自动化这些测试。不过,用户特别提到“编写应用程序”,所以可能需要自己实现这些功能,而不是依赖外部工具。 那自己编写应用程序的话,可能需要用C语言,因为嵌入式开发中C比较常见。需要考虑使用socket编程,比如创建TCP或UDP的socket,发送和接收数据。对于连通性测试,可以尝试建立TCP连接或者发送ICMP包,但ICMP在普通用户权限下可能受限,所以TCP可能更可靠。 另外,需要考虑多线程或异步处理,比如一边发送数据,一边接收,同时统计丢包率和延迟。对于带宽测试,可能需要大量数据传输,计算传输速率。这时候要注意缓冲区的大小,以及如何准确测量时间。 用户可能还需要测试不同协议,比如同时测试TCP和UDP的性能差异。UDP不保证交付,所以需要自己实现丢包检测和重传机制,或者至少统计丢包情况。 还有,错误处理也很重要。比如网线断开,网络不可达等情况,程序需要能捕获这些错误并给出提示。此外,获取网络接口的状态信息,比如通过ioctl或者读取/proc/net/dev文件,来查看接口的统计信息,比如发送接收的数据包数量,错误计数等。 自动化测试脚本的话,可以结合Shell和Python,调用各种工具,并解析输出结果。但如果是编写独立的应用程序,可能需要更底层的代码。 另外,用户可能需要交叉编译这个测试程序,因为目标平台是嵌入式Linux,开发环境可能是在主机上。所以需要确保代码的可移植性,避免依赖特定平台库,或者正确配置交叉编译工具链。 测试步骤方面,可能需要先确保网络连接正确,比如网线插入,配置IP地址,然后分步骤测试各个功能。比如先测试链路状态,然后测试连通性,接着是带宽和压力测试。 可能还需要考虑多网口的情况,如果有多个以太网接口,需要分别测试每个接口。这时候程序可能需要接受参数指定要测试的网口名称,比如eth0,eth1等。 总结下来,编写这样一个测试应用程序需要考虑以下几个方面: 1. 使用socket API进行网络通信测试。 2. 实现基本连通性测试(TCP连接或ICMP回显)。 3. 带宽测试,通过传输大量数据计算速率。 4. 丢包率测试,特别是在UDP模式下。 5. 获取网络接口的统计信息以确认数据传输情况。 6. 错误处理和状态检查,确保接口和驱动正常工作。 7. 可能的自动化脚本整合或独立应用程序开发。 现在需要把这些思路整理成一个结构化的回答,涵盖用户的需求,可能他们需要示例代码,比如用C语言写一个简单的测试程序,或者用Python脚本调用现有工具。同时要提醒注意事项,比如权限问题、交叉编译、测试环境配置等。</think>测试嵌入式Linux开发板的网络接口通常涉及硬件功能验证、驱动测试、协议栈及性能评估。以下是分步骤的测试方法及示例: ### 一、基础环境准备 1. **硬件连接** - 使用网线直连开发板与主机,或通过交换机连接 - 确保PHY芯片供电正常(可通过`dmesg | grep eth`查看驱动加载情况) 2. **IP配置** ```bash # 开发板端设置静态IP ifconfig eth0 192.168.1.100 netmask 255.255.255.0 up # 主机端设置同网段IP ifconfig enp0s3 192.168.1.200/24 ``` ### 二、自动化测试脚本示例(Python) ```python import subprocess import time def test_ping(ip, count=10): loss = subprocess.check_output(f"ping -c {count} {ip} | grep loss", shell=True) print(f"Ping测试结果:{loss.decode()}") def test_iperf(server_ip, duration=10): # 开发板端启动服务端:iperf3 -s subprocess.Popen(["iperf3", "-s", "-D"]) # 主机端作为客户端测试 result = subprocess.check_output(f"iperf3 -c {server_ip} -t {duration}", shell=True) print(f"带宽测试结果:\n{result.decode()}") def stress_test(ip): start = time.time() # 持续高压传输60秒 subprocess.run(f"iperf3 -c {ip} -t 60 -P 8", shell=True) # 检查丢包 eth_stats = subprocess.check_output("ifconfig eth0 | grep 'dropped'", shell=True) print(f"压力测试后统计:\n{eth_stats.decode()}") if __name__ == "__main__": target_ip = "192.168.1.100" test_ping(target_ip) test_iperf(target_ip) stress_test(target_ip) ``` ### 三、底层C程序测试(MAC/PHY层) ```c #include <stdio.h> #include <stdlib.h> #include <linux/sockios.h> #include <net/if.h> #include <sys/ioctl.h> #include <string.h> void check_eth_status(const char *ifname) { struct ifreq ifr; int sock = socket(AF_INET, SOCK_DGRAM, 0); strncpy(ifr.ifr_name, ifname, IFNAMSIZ); if (ioctl(sock, SIOCGIFFLAGS, &ifr) != -1) { printf("[PHY状态] %s\n", (ifr.ifr_flags & IFF_RUNNING) ? "已连接" : "未连接"); } if (ioctl(sock, SIOCGIFHWADDR, &ifr) == 0) { unsigned char *mac = (unsigned char *)ifr.ifr_hwaddr.sa_data; printf("[MAC地址] %02X:%02X:%02X:%02X:%02X:%02X\n", mac[0], mac[1], mac[2], mac[3], mac[4], mac[5]); } close(sock); } int main() { check_eth_status("eth0"); return 0; } ``` ### 四、关键测试指标 1. **协议栈测试** - TCP重传率:`cat /proc/net/netstat | grep TcpExt | awk '{print $15}'` - ARP缓存验证:`arp -n` 2. **中断性能** ```bash # 查看网卡中断计数 watch -d -n 1 "cat /proc/interrupts | grep eth0" ``` 3. **DMA测试** - 使用`memtester`工具检测内存完整性: ```bash memtester 256M 3 ``` ### 五、高级测试场景 1. **VLAN测试** ```bash vconfig add eth0 100 ifconfig eth0.100 10.0.100.2/24 ``` 2. **硬件时间戳** ```c // 启用硬件时间戳 setsockopt(sock, SOL_SOCKET, SO_TIMESTAMPING, (void *)&opt, sizeof(opt)); ``` ### 六、常见问题处理 1. **CRC错误** ```bash ethtool -S eth0 | grep crc # 若持续增长,检查网线质量或电磁干扰 ``` 2. **速度协商异常** ```bash ethtool -s eth0 speed 100 duplex full autoneg off ``` 3. **看门狗超时** ```dmesg [ +0.000001] NETDEV WATCHDOG: eth0 (macb): transmit queue 0 timed out # 需检查DMA配置或降低传输压力 ``` 建议结合`ethtool`、`tshark`进行深度协议分析,并使用`stress-ng`工具制造系统负载测试边界条件。实际测试中建议持续运行24小时压力测试以发现潜在硬件问题。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值