最近碰到一个问题,连接无线网络的时候,发现右上角网络设置中没有 Enable Wi-Fi 这个选项了,日了狗了。。。
连不上 wifi 的原因无外乎以下几点
- 网卡问题
- 没有安装网络驱动
- 安装了网络驱动,但是没有加载进内核
- 以上均没问题,那么就是路由器没有接入 internet 了
接下来,一步步排查
查看网卡信息
可以使用以下命令查看网卡信息
$ lshw -C network
正常情况至少会显示两个网卡,一个 eth0, 一个 wlan0。运行这个命令,我电脑的情况是: 两个网卡的 description 字段后面都是 unclaim,并且没有 logical name。
根据这个命令的结果,可以得出以下结论
- 网卡没有问题
- 考虑到之前能够连接 wifi,所以系统中肯定存在网络驱动
- 鉴于网卡信息识别为 “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,但是当前运行的内核版本中却没有!解决办法有两个
- 在当前内核版本中,下载相应的 ath9k.ko,并通过 insmod 命令安装
- 将当前的内核回退到 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
即可