共计 3752 个字符,预计需要花费 10 分钟才能阅读完成。
这几天看到 Ubuntu 放弃 Unity 和 Mir 开发,转向 Gnome 作为默认桌面环境的新闻,作为一个 Linux 十几年的老兵和 Linux 桌面的开发者,内心颇感良多。
Ubuntu 做为全世界 Linux 界的桌面先驱者和创新者,突然宣布放弃自己多年开发的 Unity, 相当于在桌面领域,直接放弃了战斗向微软投降,不仅仅是 Linux 桌面的悲哀,更是对于全球 Linux 黑客坚信 Linux 必胜信心的极大打击。
曾经的 Ubuntu 粉丝
我还记得 2006~2007 年,那时候我还在成都写手机游戏,当时年少轻狂的我,一直幻想自己要做最牛掰的开发者,就像科幻电影里面的黑客一样,无所不能。那时候虽然 Windows 玩的很溜,但是一直都在核心技术外徘徊,不知道如何达到个人目标。
上学的时候玩过 RedHat 6.0, 也装过 KDE/Gnome 的桌面环境,但是系统中的各种问题,比如无法使用输入法、中文字体配置很差,甚至因为显卡驱动的原因都无法正常开机,所以 Linux 对于当年的我来说,就像神话一样,只有顶级黑客才能玩的转的系统。
直到后面用了 Ubuntu 6.10 和 Ubuntu 7.04, 当时的 Ubuntu 可以说是非常惊艳,原来 RedHat 和 SUSE 在桌面端的各种细节问题一扫而光,装上系统以后就可以直接用,而且还可以非常容易的安装应用软件来深入学习 Linux。可以说是 Ubuntu 带领我真正的入门了 Linux,经过很多年的深入学习 Linux, 到后来在 Linux 上开发 Emacs 和 Haskell 相关的项目,直至后面创业做 deepin 操作系统。
从我个人来说,对 Ubuntu 系统以及背后的开发者都是怀着无比的敬畏和崇拜。
我看这么多年 Ubuntu 的发展
Ubuntu 从当年最佳的 Linux 桌面操作系统到今天宣布放弃自己研发的 Unity 桌面,已经有 13 年历史了,在我看来主要有以下几个阶段:
最初的惊艳
Ubuntu 最初的发展目标就是把原来 Linux 系统需要手动操作的基本配置,比如字体、输入法和显卡驱动等问题内置到操作系统中,用户不用安装系统后还需要跟乱码、中文输入以及显示等问题斗智斗勇,可以说那个时代的 Ubuntu 是解决了当时 Linux 普及的几个重要问题,把 Linux 系统从当时只有开发者才能玩转的高手系统普及到普通的电脑爱好者就可以折腾使用。
酷炫的 Compiz 管理器
我相信很多 Linux 爱好者都惊叹于当年 Compiz 这个 3D 窗口管理器能够达到的酷炫效果,比如 3D 旋转桌面、拖动窗口的果冻效果、一把火烧掉窗口的效果… 特别是同时代的 Windows 系统都还是非常原始的 2D 效果,甚至 XP 的窗口连窗口阴影都还没有的时候。当时的 Linux 系统的,特别是 Compiz 吸引大部分用户去尝试 Linux 系统,即使最后大家仅仅只是因为好奇或是玩玩,也大大增强了 Linux 系统的曝光率。
从另外一方面,Linux 从当年 Compiz 发展十年以后,反而是那些简单特效甚至没有特效的 Linux 系统得到最高的用户量,原因我觉得主要有两个:
- PC 这种生产力的工具最重要的是高效,非常酷炫的特效长时间用,反而会极大干扰用户视觉,进而影响用户对内容的专注力,而且时间长了也很容易引起用户的视觉疲劳,反而是 Mac 那种恰到好处的轻微动画让用户感到优雅和舒服, 这方面 Linux 发行版 Elementary OS 做的要好很多
- 任何操作系统需要长久留住用户,还是需要靠优秀的人机交互设计和丰富的应用来留住用户,操作系统只有给用户带来真实的价值,让用户工作更高效和生活更快乐,用户才会长期坚持下去,光靠酷炫的动画吸引,用户一旦视觉疲劳以后,最终还是会放弃 Linux,因为一个操作系统不能解决用户日常遇到的各种问题,在用户心中最多就是一个好玩的玩具而已
Gnome3 vs Unity
在 2011 年底,Gnome 发布了它最新的 Gnome3 系统,当时 Gnome3 以酷炫的特效加上 JavaScript 的插件体系而吸引了开源社区开发者的兴趣,特别是 Gnome3 内置 GJS 引擎,可以直接在桌面环境中编写 JavaScript 插件后直接 reload 即可更新桌面环境的功能和视觉效果,还有吊炸天的 inspector 特性,可以直接通过鼠标点击界面后定位到对应的代码位置,再加上 GJS 可以从屏幕顶部打开一个类似 quake terminal 的下拉调试环境,在调试环境中直接像脚本语言那样实时列出任何对象的属性和方法,立即改立即生效。
上面这些开发者特性,在那时候 Google 满天吹嘘 Html5/JavaScript 的美好未来的大环境下,对于开发者有极大的诱惑力,很多开发者都奔着 Gnome3 这些类似 Web 的开发方式而去,并贡献了大量好玩的插件。
在 Gnome3 之前,Ubuntu 一直都在用 Gnome2 桌面环境,其实 Gnome3 在 2011 年发布之前已经规划了 2 年,从当时的宣传来说是下一代桌面环境,2009, 2010 年 Gnome3 还在社区发布了大量吊炸天的预览视频。作为当时桌面系统先锋的 Ubuntu 也非常期待能用上 Gnome3。而无奈 Gnome3 一次又一次跳票,最后 Ubuntu 实在等不及了,就在 Gnome2 桌面环境后台服务的基础之上,开发了自己的 Unity UI。
当时社区也因为 Unity 和 Gnome3 的很多设计理念类似谴责 Ubuntu 在进行分裂行为。
Unity 产品的特点主要定位在几点:
- HUD 的左上角搜索设计,快速搜索应用和很多插件提供的搜索结果,这一点和 Gnome3 的 Launcher 插件体系非常像,通过插件,可以搜索除应用外的更多搜索结果(比如天气、在线视频、计算器结果等)
- 任务栏固定在左边,对宽屏更加优化,相对于程序员有更多的纵向空间
- 全局菜单,通过合并顶部栏和窗口标题栏,进一步节省纵向空间
我个人并不喜欢这些面向开发人员(而不是面向普通用户)的设计,但是撇开个人的主观设计喜好外,我认为 Unity 是相对于 Gnome3 更成熟的产品,Unity 的很多改动都是针对 PC 桌面系统的真实痛点来改进的,特别是一些程序员的用户很喜欢 Unity 诸多设计。而不是像 Gnome3 那样一味的追求平板用户体验,极大降低了 PC 桌面用户的习惯和易用性,Gnome3 的槽点我后面详细说。
不论从商业公司的独立性发展考虑还是产品质量负责的角度,我都是非常支持 Ubuntu 当时独立开发自己 Unity 桌面环境的行为,Unity 确实在随后的几年证明了自己的产品质量和设计细节都比 Gnome3 要好很多。
Wayland vs Mir
在 Gnome3 和 Unity 发展的同时,Intel 的雇员 Kristian Høgsberg 正在领导开发新的显示服务器。Wayland 相对于古老的 X11 来说最大的提升是,Gtk/Qt 这些图形库进行图形绘制时,不用像 X11 那样发送绘制消息到 XServer 来进行绘制,而是由 Client 自己进行图形绘制,Wayland 只用担任图层混合器的作用。这样不但减少了 X Client 和 X Server 之间不必要的通讯,而且因为由 Client 自己进行渲染,所以很多画面撕裂和闪屏的现象从原理上就避免了。
大家可以看一下下面的两张架构图来理解两者的差别:
Wayland 因为要彻底从技术架构上颠覆 Linux 几十年 X11 的渲染方式,不论从架构设计还是代码实现上都会非常复杂,不但要开发协议本身,还需要开发适合 Wayland 的混合器和窗口管理器,最后导致 Wayland 1.0 稳定版一再跳票。
而 Ubuntu 在独立开发 Unity 桌面环境的同时,也仿造了 Wayland 的架构开发了自己的 Mir 显示服务器,除了等不及 Wayland 稳定之外,更重要的是 Ubuntu 要为了它的下一步宏伟计划”Ubuntu Touch”,按照 Mark 的设想,Mir 不仅仅要像 Wayland 那样从原理上提升 Linux 图形渲染效率,而且 Mir 还得担负起手机和电脑融合的使命,可以让 Ubuntu Touch 的手机在插上显示器底座时,手机的应用通过 Mir 的支持,可以直接在外接显示器上显示手机应用窗口,最终达到“当你手机放到底座时就是电脑,拿走就是手机”的设想。
不论 Wayland 还是 Mir,虽然底层架构都非常先进,但是为了兼容现有的 X11 程序,它们分别开发了 XWayland 和 XMir 用于在新的显示服务器协议上支持现有的大多数 X11 程序(主要是 Gtk2/Qt3/Qt4 开发的大多数应用)。
具有讽刺意味的是,Wayland 和 Mir 本来就是要解决 X11 那种不适合现代 PC 场景繁琐的通讯协议,甚至很多开发者为了技术的洁癖都在大力安利 Wayland/Mir,但是最后 XWayland 和 XMir 本身的兼容实现却比 X11 的实现更加“恶心”和繁琐,包括 Mir 的开发者最后都放弃 XMir 的开发。
正是因为 Wayland/Mir 这样的技术无法彻底解决和大部分原本就基于 X11 协议而开发的应用的兼容性问题,最后导致基于 Wayland/Mir 开发的桌面系统从”解决渲染性能问题“转变到“无法运行很多现有 Linux 应用”这一个更加让用户难以接受的结果。这也是后面基于 Mir 开发的新版 Unity 难产的重要原因。