Ubuntu 网络故障排查

作者: accepting | 来源:发表于2016-07-31 14:07 被阅读292次

    最近碰到一个问题,连接无线网络的时候,发现右上角网络设置中没有 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上 ……
        accepting:@不乱于心_不困于情 你的具体问题是什么诶,先参考下网上的方案吧 http://jingyan.baidu.com/album/76a7e409bad732fc3b6e15fa.html

      本文标题:Ubuntu 网络故障排查

      本文链接:https://www.haomeiwen.com/subject/flotsttx.html