喔,看到这个标题千万不要以为我要写和王垠前辈一样的内容啊,嘿嘿。不过在这里还是献上王垠前辈的那篇文章的链接吧:完全用 Linux 工作[1]。

为什么要写这篇文章?

首先介绍本篇文章产出的时间,现在是 2020/08/22。在三,四天之前,我其实并没有写这篇文章的打算,但是这三,四天以来,我一直在忙活从 Ubuntu18 换到 Debian10 Buster 的事情,没有时间写代码,手确实有些痒了。你可能想象不到,我这个之前一直使用 Ubuntu 的人,只是切换到 Debian 就花这么长时间,你可能以为我是在劝退各位同学,其实不是的,我只是想表达:我对 Linux 并不熟悉,这其中一部分原因是我使用的是对用户较为友好的发行版 Ubuntu,另一部分原因是我仍然没有那么大的动力去学习 Linux,即使它一直作为我的日常使用。

这篇文章并不是吹嘘或贬低 Windows 和 Linux 系统,而是想记录一下我一直以来使用 Linux 作为日常学习的心得,以及这几天再度折腾 Debian 以来的感触。

为什么我要从 Windows 切换到 Linux?

Windows 是商业软件,这使它具备易用的性质。Linux 是自由软件,这使得它拥有开源的性质。

易用软件通常带来的是对用户的友好度,以致于 Windows 发展至今,被许许多多的普通用户所采用。自由软件通常带来的是其社区的发展,所以你现在可以在网上看到许多如 ask ubuntu 这样的论坛。

我非常赞同《完全用 Linux 工作》中的一个观点: UNIX 不是计算机专家的专利。

我对这句话的理解就是:即使你学习或工作的方向不是计算机,但你仍然可以去学习 Unix/Linux,如果你是计算机方向的同学,那么,你就更应该去学习 Unix/Linux 了。

但这只是我从 Win 切换到 Linux 的一部分原因,另一个很重要的原因是我受够了 Windows 的 “易用性”。这里的易用性并不是说我排斥 Windows 的人性化,而是因为人性化给我带来了很多学习上的困难。举个很简单的栗子:你在学习一项技术的时候,无论是否有面试造火箭的需要,你是否都会好奇想了解其原理和实现,即使你可能知道它很复杂。

为什么你会好奇一个事物的源头?

我个人认为的答案是:有趣的事情就在眼前,为什么不去了解它呢?

而 Windows 只是有趣,但它并不在“眼前”。

我个人的体验哈,不知道有没有同学和我一样的经历,在很多时候,你的 Windows 可能会出现一些莫名奇妙的问题,但你却不知道如何解决它,你只能求助搜索引擎,当你解决完问题后,你不会想要去了解为什么会发生这种问题,因为 Windows 太庞大了。

就比如: 我现在安装了 Git,使用起来没有任何问题。但等到过一段时间后,Git 莫名奇妙的不能使用了,明明你啥都没干。更甚之,有一些流氓问题或流氓软件不能被解决和被屏蔽。

问题出现了,总得要解决吧,所以此时你开始在互联网上查询相关问题的解决方法,如果你的运气好,那么有人可能遇到过和你出现相同的问题,你也因此可能会得到答案。不过一般的答案只是教你怎么解决的,如打开注册表,添加或删除某个 key,你不会想要知道为什么做,因为对于初学者来说,当你看到注册表那么多的内容时,你只想着不出错就行了,哪还有心思去学习这玩意啊。如果你的运气不好,且并没有更换系统的打算,那么你可能会将就着使用,但此时,你的心里可能已经衍生了对 Windows 的厌烦情绪。

我对流氓软件的定义是:当你想让一个软件如你的想法停止运行或停止弹出广告的时候,这个软件不能或不能做的很好的达到你的要求时,这就是一个流氓软件。你也许会说,每个人都有不同的要求,软件怎么可能达到每个人的标准呢?但我指的是停止和停止弹出广告等这样最基本的诉求,如果一个软件连最基本的诉求都实现不了,又何必再使用它呢?

综上所述,我从 Window 切换到 Linux 的最主要的原因有:学习和自由。

是的,你不得不承认 Linux 是你学习计算机的非常好的环境,与 C/C++天然的集成,比你在 Windows 上冷冰冰的安装一个 IDE 就开始敲起代码来,显得多了那么一点感觉。

还有一点,可能有的同学和我一样,刚接触 Linux 的时候,是在 Windows 上安装一个虚拟机环境或使用 Docker 来进行学习。不可否认,这确实是在 Windows 上学习 Linux 的主要途径了,但是你有没有感觉到,你在采取这种方式学习的时候,对 Linux 始终有种陌生感,似乎我只是在为了学习而学习。

产生这种想法的主要原因就是你没有融入到 Linux 环境之中,当你融入到 Linux 环境之中时,你不再只是需要学习那些操作命令,你会不可避免的遇到某个你从来没有接触过的问题,这个问题不是你在 Windows 上“丢失图标”的那种烦人问题,而可能是令你有些害怕的因为 Nvidia 的驱动而黑屏的问题。你也会在互联网上查询为什么会出现这种问题,但你得到的并不是“修改注册表”这种答案,而是会学习到:为什么 Nvidia 在 Linux 上会出现这种问题?我怎么做才能解决驱动问题?其他驱动是否也有类似 Nvidia 这种问题?当你解决问题后,你的电脑开始正常工作了,你便开始使用它作为你的日常使用...

关于使用 Linux 学习的原因的最后一点是我认为自己不够慎独,不够克制。 当我使用 Windows 的时候,并不能完全克制住自己接触那些新鲜游戏的念头,我玩起游戏来,通常会连续很长时间,可能是一天-_-。不过我并不是说 Linux 上没有游戏,相反,Linux 是对很多游戏的支持是很好的,你可以玩到很多游戏,但你是否会因为使用 Linux 对游戏不再那么执着,至少我是如此了。这一点可以归结为“使用 Linux 对戒游戏有帮助吧” ,哈哈。

再谈谈自由:我对自由的理解是:软件在你的掌控之中,你可以了解它的每一部分,你可以去到你想到达的地方,不受任何限制,这只取决于你愿不愿意。

来看看基本的 Linux 目录吧:

Linux目录

这些目录你可能有很多都不认识,但没关系,因为这就是 Linux 系统(大部分)所有的目录了,你稍微了解下,就知道这些目录里放的是什么文件了。

这也是我个人的体验而已,总之,Linux 的自由是一种开源精神,比我描述的可大的多。至于 Windows,我到现在连 C 盘的目录放了些什么都不太熟悉,但我并不是在贬低 Windows,因为这就是 Windows 易用性的代价,相应的,Linux 作为自由软件,它也有很多缺点。

Linux 作为日常使用的缺点

硬件驱动问题

硬件驱动问题一般是在安装 Linux 时会出现的问题,根据个人电脑配置的不同,你的电脑的硬件驱动可能与要安装的 Linux 发行版不兼容,导致系统出现相应的问题。我这几天对驱动问题最深刻的体会就明白了为啥 Linus 大神会吐槽: “Nvidia Fuck You”。很多驱动厂商对 Linux 系统是闭源的,你可以下载这些厂商的驱动,但是能不能用,或者用起来有什么毛病都得你自己买单。

随着 Linux 开始在普通用户中变得流行起来,我相信今后 Linux 的生态会发展的越来越好,且现在很多 Linux 发行版对各种硬件的兼容性也越来越好,就以我之前使用的 Ubuntu18 来说,Nvidia,Wifi,蓝牙等驱动使用都是没啥问题的。我现在使用的 Debian10 Buster 对 Nvidia 的支持可能还不是那么好,使用起来总有一些小毛病,不过无伤大雅,其实没毛病我还有点不适应,不是说 Debian 是 Ubuntu 的爸爸吗,哈哈。

软件问题

不得不承认的一点是 Linux 的软件生态确实没有 Windows 那么丰富,你在考虑切换系统之前,必须先调查清楚 Linux 上是否有你必需的软件,你所需的软件是否支持跨平台或者是否有可替代的应用。我个人对软件要求较为简单,大部分都是生产力工具,其他的应用如娱乐软件之类的都可以使用网页版作为替代。如果你在 Linux 系统上想尝试游戏的话,我认为也是 OK 的,因为我也尝试过 Linux Dota2 ,体验非常好(不是广告-_-)。不过大多数国内游戏厂商对 Linux 的支持都是很差的,所以如果过不了这道坎,也不要切换系统了。

软件问题其实可以分为 2 部分看待,一部分就是刚刚介绍过的生态问题,另一部分就是当你在使用某些软件的时候,总会出现某些小 Bug。

就以 Fcitx 来说,Fcitx 是一款通用的 Linux 输入法框架,被称为小企鹅输入法,很多输入法都是在 Fcitx 之上开发的,如搜狗,Googlepinyin,Sunpinyin 等。使用过 Fcitx 的同学可能会遇到这种问题:当你在使用 Fcitx 在某些软件上打字时,候选框并不会跟随你光标的位置,而是总会固定在某一个位置,并且你无法改变,这个问题是我目前见过的最大 Bug。不过这个 Bug 只在部分软件上有,在 Chrome,Typora 上都没有这个问题,这让我怀疑是软件的国际化问题,而非 Fcitx 问题。

所以第二个部分总结起来就是某些软件可能会出现某些未知的 Bug,你得寻求解决的办法,或者忍耐使用,使用 Linux 也是得牺牲一些代价的。

你真的需要完全使用 Linux 吗?

说到这里,其实我想借用知乎某位前辈的话来表达一下我的真实想法: “Linux 最好的地方在与开放自由,最大的毛病也是在这里。普通人没有能力去选择,也没有时间做选择。透明就一定好么?也有很多人喜欢被安排啊!“

就像我开头说过的: “我对 Linux 并不熟悉,这其中一部分原因是我使用的是对用户较为友好的发行版 Ubuntu,另一部分原因是我仍然没有那么大的动力去学习 Linux,即使它一直作为我的日常使用。”

我完全使用 Linux 是为了学习和自由,我确实在 Linux 上感受到了自由,且学到了很多东西,但我却一直沉溺在这种使用 Linux 带来的满足感之中,并不能真正理解 Linux 给我们带来的到底是什么。

这次从 Ubuntu 切换到 Debian 的原因是我想尝试换个新的环境,但是当我花了 3,4 天后,我明白了:我只是呆在一个地方久了,想换个新地方而已,但老地方不一定坏,因为我都没怎么了解过这个老地方,就像当初我从 Windows 换到 Linux 那样,我都没有深入的了解过 Windows 就换了,那一段时间我还抱怨 Windows 的各种缺点,现在看来,非常可笑。

结尾

一文把想说的话几乎都给说了,个人文笔有限,且本文主观意识太强,如果觉得本文不符合您的胃口,就当看个笑话吧。

我使用 Debian/Ubuntu 时遇到的问题

以下内容是我在 Debian10 Buster 下遇到的问题以及相关解决办法, 使用 Ubuntu 和 Debian 其他版本的同学也可借鉴。PS:欢迎各位同学在此处写下你遇到的问题和解决办法。

IDEA 编辑 Markdown 预渲染问题

这个问题花了我很长时间。当我安装 IDEA 后,使用它编辑 markdown 文件的时候,就出现了如下图所示的情况:

Debian10下IDEA的Markdown预渲染问题你可以看到右边渲染的画面明显有问题。刚开始的时候我一度怀疑是 IDEA 版本的问题, 于是我又安装 IDEA 其他版本,但也没有任何作用,这时我怀疑是显卡的原因:


我的电脑配置

可以看到使用的是 Intel 的核显,于是当我查询相关资料,使用脚本将核显换为了独显,这里没留截图,当你换到独显后, 图形会显示独显的配置,使用 nvidia-smi 命令可以查看独显使用状态。于是我满怀期待的打开 IDEA,但还是无济于事。当我以为真的是 Debian 的 Bug 的时候, 我又发现 Bumblebee 可以管理显卡,何不一试?于是我安装 Bumblebee 后,使用 optirun 命令启动 IDEA,没想到啊, 还真是可以:


Debian10下IDEA的Markdown预渲染解决后

我真的就很奇怪,同样是使用了独显,为什么 optirun 启动就可以正常显示。于是我后来又查询 optirun 是否开启了 gpu 加速,但很可惜,我并没有得到相关答案,不过这让我确定了这个问题出现在 显卡上。如果有知道原因的同学,敬请告之,感激不尽。

wifi 适配器找不到

我猜(不确定)这个问题应该发生在大多数使用联想笔记本的同学的电脑上,不止 Debian,且 Ubuntu 也有这个问题。当安装完系统后,我们打开设置会发现 wifi 一栏显示 “wifi 适配器找不到” 此类的错误信息。这个问题的大概原因是:无线网络适配器被阻塞了,需要手动将电脑上的 wifi 开关打开,而在我的笔记本上并 wifi 开关, 所以可以猜测是联想网络驱动的问题。可以使用 rfkill list all 命令查询你的 wlan 是否被阻塞了,没有此命令的同学可以使用

sudo apt-get install rfkill

安装,当 wlan 显示 Hard blocked: true , 就证明你的无线驱动被阻塞了。解决办法是将阻塞无限驱动的那个模块从内核中移除掉,直接在 /etc/modprobe.d 目录下编辑 blacklist.conf 文件,其内容为:

blacklist ideapad_laptop

文件名不一定要与我的一致,但是要以.conf 结尾。你可以将 modprobe.d 目录下的文件理解为黑名单文件, 当 Linux 启动时就不会加载 conf 文件指定的模块, 这里的 ideapad_laptop 就是我们需要移除的那个无线模块。后遗症:当我们移除 ideapadlaptop 模块后,以后开机的时候,有时会出现 蓝牙适配器找不到的情况,之前在 Ubuntu 上却并未发现这种问题, 看来 Debian 在驱动方面没有 Ubuntu 做的好,不过这也是可以理解的, 而且大多数时候还是可以正常使用的--。

XMind 安装

XMind 是使用 Java 编写的,依赖于 Openjdk8。所以在 Linux 上使用 XMind, 首先需要有 Openjdk8 的环境。其次启动的时候需要编写 Shell 脚本来启动(不是唯一办法,但却是非常简单的办法),没想到吧,我也没想到, 这也是我趟过很多坑才玩出来的。首先我们需要准备一张 XMind 的软件启动图片:XMind.png, 这个我已经放到目录[3] 下了,需要的同学请自取。其次我们进入 XMind_amd64 目录下,32 位系统的同学进入 XMind_i386 目录, 我们创建并编辑 start.sh 脚本,其内容为:

#!/bin/bash cd /home/guang19/SDK/xmind/XMind_amd64 (这个路径为你的XMind脚本的路径) ./XMind

这个脚本的内容很简单吧,当启动脚本的时候,进入目录,直接启动 XMind。脚本写完后需要让它能够被执行,使用

chmod +x start.sh

命令让 start.sh 可以被执行。此时你可以尝试执行 ./start.sh 命令来启动 XMind,启动成功的话, 就已经完成了 99%了,如果启动不成功,可以再检测下前面的步骤是否有误。如果以后你只想用 Shell 启动 XMind 的话,那么到此也就为止了,连上面所说的图片都不需要了。如果你想更方便的启动的话,那么就需要创建桌面文件启动。在 Debian/Ubuntu 下,你所看到的桌面文件,都存储在 /usr/share/applications 目录下面(也有的在.local/share/applications 目录下),这个目录下文件全是以.desktop 结尾。我们现在就需要在这个目录下创建 xmind.desktop 文件(名字可以不叫 xmind)。其内容为:

[Desktop Entry] Encoding=UTF-8 Name=XMind Type=Application Exec=sh /home/guang19/SDK/xmind/XMind_amd64/start.sh Icon=/home/guang19/SDK/xmind/XMind.png

我们暂时只需要理解 Icon 和 Exec 属性。Icon 就是你在桌面上看到的应用的图标,把 Icon 的路径改为你 XMind.png 的路径就行了。再看 Exec 属性,当我们在桌面上点击 XMind 的图标的时候,就会执行 Exec 对应的命令或脚本, 我们把 Exec 改为 start.sh 文件的路径就行了,别掉了 sh 命令,因为 start.sh 是脚本, 需要 sh 命令启动。以上步骤完成,保存 desktop 文件后,你就可以在桌面上看到 XMind 应用了。

Fcitx 候选框的定位问题

这个问题贴一张我处境的截图就明白了:


Fcitx候选框定位问题

可以看到我的光标定位在第 207 行,但是我输入法的候选框停留在 IDEA 的左下角。为什么我要说停留在 IDEA 的左下角?因为就目前我的使用而言,这个问题只在 IDEA 下存在, 不仅是 Debian,Ubuntu 也存在这种问题,我个人认为这应该是 IDEA 的问题, 查到的相关文章大部分都是说 Swing 的问题,看来这个问题还真是比较困难了。如果有同学知道解决办法,还请不吝分享,非常感谢。