Ubuntu系统网络故障排查的方法
一、首先说明的是连不上 wifi 的原因无外乎以下几点
1、网卡问题
2、没有安装网络驱动
3、安装了网络驱动,但是没有加载进内核
4、以上均没问题,那么就是路由器没有接入 internet 了
接下来,一步步排查
二、查看网卡信息
可以使用以下命令查看网卡信息
$ lshw -C network
正常情况至少会显示两个网卡,一个 eth0, 一个 wlan0。运行这个命令,我电脑的情况是: 两个网卡的 description
字段后面都是 unclaim
,并且没有 logical name。
根据这个命令的结果,可以得出以下结论
1、网卡没有问题
2、考虑到之前能够连接 wifi,所以系统中肯定存在网络驱动
3、鉴于网卡信息识别为 “unclaim
”,网络驱动应该没有在运行,即没有加载进内核
所以,接下来要做的便是: 找到和网卡相关的驱动,然后加载进内核
三、寻找网卡驱动
运行以下命令
$ vim /etc/udev/rules.d/70-persistent-net.rules
结果如下
# 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
检查以上驱动模块是否在运行
$ lsmod | grep "ath9k"
发现没有任何输出,这个证明模块 ath9k.ko
没有被加载
下面检查系统中是否真的已经有这个模块
$ find / -name "ath9k.ko"
结果为
/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
下。此时,我们查看以下当前系统的内核版本
$ uname -r
结果显示的是
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 启动选项
$ vim /boot/grub/grub.cfg
在打开的文件中,存在诸多的 menuentry,每个 menuentry 对应开机菜单中的一个选项,找到 3.13.0-79-generic
内核对应的 menuentry,确定它的位置序号,第一个 menuentry 位置为 0,逐次加 1。
然后修改 /etc/default/grub
中的 GRUB_DEFAULT
值为刚才那个序列号
最后运行 update-grub
,以及 reboot
即可
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家能有一定的帮助,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。