Ubuntu系统网络故障排查的方法

时间:2022-05-07 13:16:24

一、首先说明的是连不上 wifi 的原因无外乎以下几点

     1、网卡问题

     2、没有安装网络驱动

     3、安装了网络驱动,但是没有加载进内核

     4、以上均没问题,那么就是路由器没有接入 internet 了

接下来,一步步排查

二、查看网卡信息

可以使用以下命令查看网卡信息

?
1
$ lshw -C network

正常情况至少会显示两个网卡,一个 eth0, 一个 wlan0。运行这个命令,我电脑的情况是: 两个网卡的 description 字段后面都是 unclaim,并且没有 logical name。

根据这个命令的结果,可以得出以下结论

     1、网卡没有问题

     2、考虑到之前能够连接 wifi,所以系统中肯定存在网络驱动

     3、鉴于网卡信息识别为 “unclaim”,网络驱动应该没有在运行,即没有加载进内核

所以,接下来要做的便是: 找到和网卡相关的驱动,然后加载进内核

三、寻找网卡驱动

运行以下命令

?
1
$ vim /etc/udev/rules.d/70-persistent-net.rules

结果如下

?
1
2
3
4
5
# PCI device 0x10ec:0x8168 (r8169)
SUBSYSTEM=="net", ACTION=="add", DRIVERS=="?*", ATTR{address}=="54:53:ed:31:c3:29", ATTR{dev_id}=="0x0", ATTR{type}=="1", KERNEL=="eth*", NAME="eth0"
 
# PCI device 0x168c:0x0032 (ath9k)
SUBSYSTEM=="net", ACTION=="add", DRIVERS=="?*", ATTR{address}=="08:3e:8e:d8:10:95", ATTR{dev_id}=="0x0", ATTR{type}=="1", KERNEL=="wlan*", NAME="wlan0"

从这里得知,eth0, wlan0 的驱动分别是 r8169.ko, ath9k.ko

检查以上驱动模块是否在运行

?
1
$ lsmod | grep "ath9k"

发现没有任何输出,这个证明模块 ath9k.ko 没有被加载

下面检查系统中是否真的已经有这个模块

?
1
$ find / -name "ath9k.ko"

结果为

?
1
2
3
/lib/modules/3.13.0-32-generic/kernel/drivers/net/wireless/ath/ath9k/ath9k.ko
/lib/modules/3.13.0-79-generic/kernel/drivers/net/wireless/ath/ath9k/ath9k.ko
/usr/lib/debug/lib/modules/3.13.0-79-generic/kernel/drivers/net/wireless/ath/ath9k/ath9k.ko

以上说明模块 ath9k.ko 确实存在!但是,等等,上面前面两个 ath9k.ko 分别处在不同的内核模块下,即 3.13.0-32-generic 3.13.0-79-generic 下。此时,我们查看以下当前系统的内核版本

?
1
$ uname -r

结果显示的是

?
1
3.13.0-92-generic

到这里问题已经很明朗了,我们系统中确实存在无线网卡驱动模块,ath9k.ko,但是当前运行的内核版本中却没有!解决办法有两个

     1、在当前内核版本中,下载相应的 ath9k.ko,并通过 insmod 命令安装

     2、将当前的内核回退到 3.13.0-79-generic 版本

由于我这里不仅仅是无线模块没有加载,eth0 模块也没有,所以猜测是因为系统在升级到 3.13.0-92 的过程中,发生错误导致的,所以,我这里选择将系统回退。

四、系统回退

由于系统上已经存在 3.13.0-79-generic,所以不需要下载,安装

修改 boot 启动选项

?
1
$ vim /boot/grub/grub.cfg

在打开的文件中,存在诸多的 menuentry,每个 menuentry 对应开机菜单中的一个选项,找到 3.13.0-79-generic 内核对应的 menuentry,确定它的位置序号,第一个 menuentry 位置为 0,逐次加 1。

然后修改 /etc/default/grub 中的 GRUB_DEFAULT 值为刚才那个序列号

最后运行 update-grub,以及 reboot 即可

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家能有一定的帮助,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。