Ubuntu 网络故障排查

最近碰到一个问题,连接无线网络的时候,发现右上角网络设置中没有 Enable Wi-Fi 这个选项了,日了狗了。。。

连不上 wifi 的原因无外乎以下几点

  • 网卡问题
  • 没有安装网络驱动
  • 安装了网络驱动,但是没有加载进内核
  • 以上均没问题,那么就是路由器没有接入 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 即可

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Ubuntu的发音 Ubuntu,源于非洲祖鲁人和科萨人的语言,发作 oo-boon-too 的音。了解发音是有意...
    萤火虫de梦阅读 99,584评论 9 467
  • 系统启动是一项非常复杂的程序,因为内核得先检测硬件并加载适当的驱动程序后,接下来则必须要调用程序来准备好系统运行的...
    Zhang21阅读 11,776评论 3 10
  • 1. 简介 本文档包含DPDK软件安装和配置的相关说明。旨在帮助用户快速启动和运行软件。文档主要描述了在Linux...
    半天妖阅读 17,995评论 0 22
  • hexdump -C 查看二进制文件 xxd:查看二进制文件 whatis 简单描述命令的用途whatis c...
    JevonWei阅读 849评论 0 0
  • linux资料总章2.1 1.0写的不好抱歉 但是2.0已经改了很多 但是错误还是无法避免 以后资料会慢慢更新 大...
    数据革命阅读 12,237评论 2 33