为什么Arch Linux不适合作为服务器操作系统

我前面好几篇文章都有关Arch Linux,我本人也是虔诚的Arch邪教教徒,但是有人经常会问:为什么Linux服务器几乎从不采用Arch Linux?我们见得多的Linux服务器系统一般都是什么Ubuntu Server啊,什么Cent OS啊,什么Fedora啊,或者企业采用的Red Hat啊,为什么几乎没有Arch Linux呢?下面我将从若干个方面指出Arch Linux在服务方面的劣势。

1、过分激进的滚动更新

滚动更新是Arch Linux最大的优势,但同时也是最大的劣势之一。鉴于Linux属于一类完全开放的项目,技术人员的能力参差不齐,贡献的代码质量当然也是参差不齐的。对于其它的发行版来说,软件包需要经过社区完善的测试才会被发布至软件源从而被用户更新;然而,Arch Linux的滚动更新机制过分激进,而Arch社区对软件包的测试并非绝对完善(有多少人滚挂过?)。从某种意义上来讲,Arch这个发行版,相当依赖其用户群体作为测试对象;它的用户群体就是类似测试人员的存在。Arch社区鼓励用户向上游反馈Bug,也是这种特殊的体系的表现。下图是Arch官网时不时会发布的、用以帮助技术人员手动解决更新问题的“临时解决方案”:

假如一台Arch服务器在更新时滚挂了,技术人员顶着Boss的压力,不仅要一边努力恢复服务器,还要一边向Arch社区的上游反馈Bug、提Issue。这种事情谁都不愿意干的吧。

2、激进的内核更新机制

很多Linux桌面用户不止一次地问过我,为什么他们的桌面Linux在更新的时候不会像Arch一样立即删除旧的内核?这样不是会浪费空间吗?

这种立即删除旧内核的更新机制也是Arch作为服务器的劣势之一。首先,新的内核不一定都能正常工作。万一你的新内核造成崩溃,你没有办法立即加载旧的内核,而必须重新安装旧的内核。这个过程是非常麻烦的,你不仅需要从安装介质启动,还必须设法弄到旧版内核的软件包。对于远程服务器来说,几乎无解。下面是来自Arch Wiki的解决方案。可以看得出来这有多么麻烦:

其次,立即删除旧的内核要求系统必须重启来加载新的内核,否则容易发生诡异的问题。这是因为Linux所谓的“内核”包含有大量的动态加载模块,如果在某次启动后,某个模块没有被加载过,然后系统内核更新了,删除了旧的内核,那么这些模块将永远不能被加载了——除非你重启系统完整切换到新的内核——因为它们随着旧内核被删掉了。

如果你手头有Arch系统,你可以尝试一下在某次启动之后不插任何USB设备,然后更新内核。你会发现,如果你不重启系统,无论你怎么努力,新插上去的USB设备总是不会被加载——因为需要被加载的模块已经随着旧内核删掉了。重新启动系统能完整切换到新的内核,以使用新版的动态加载模块。

但是对于服务器来说,不可能三天两头重启;然而Arch Linux却又是一个一周一小更,一月一大更的快速迭代的操作系统。这就使Arch不适合作为服务器操作系统。

3、软件包管理体系

Arch Linux被推崇很大一部分的原因是便于使用的软件包管理体系。不同于Debian系列的apt/dpkg和Red Hat系列的dnf(yum)/rpm包管理体系,Arch Linux只用了一个工具pacman就解决了获取和安装两个功能。这降低了为Arch Linux制作软件包的门槛,这也是AUR几乎能涵盖整个Linux软件生态的主要原因。

既然一个工具就能完成工作,那为什么另外两个主流系列都依然存在两个工具来管理软件包体系?这是因为,这种两个工具来管理软件包的体系中,那个负责处理本地依赖和本地包的部分,不仅仅是为了管理依赖、安装软件包而存在的。它还有更有用的功能:提供“虚包”支持。提到“虚包”就不得不提到Java这个平台,因为Java的开放,常见的Java运行时环境有两种:一个是Oracle官方的JRE,另一个是开源社区创建的Open JRE。它们都对Java提供很高程度的支持,但是依然存在微妙的差别。比如Android Studio使用Open JRE运行就会偶尔出现奇怪的Bug,而另外有一小部分软件则不能正常运行在Oracle JRE上。它们都提供JRE的支持,但是对于Debian或者Red Hat来说,二者是能共存的:dpkg或者yum可以决定对于哪些应用程序选取哪个JRE为应用程序提供JRE依赖。

但是对于pacman来说,虚包支持什么的,不存在的。只能有一个软件包提供JRE支持:安装一个就必须删除另一个。对于服务器来说这就相当尴尬了:并不能保证所有的程序都能找到完美的依赖。

4、打包粒度

虽然最近几年有所改善,但是Arch Linux的打包粒度对于服务器来说还是过分大了。我们也许只会用到某软件包的一部分,但是pacman会把整个软件包给你装上——你还没得选。对于服务器来说,为实现功能所安装的软件包越少越好——一来节省资源,二来可以减少由软件体系带来的漏洞。这也是Arch不适合作为服务器操作系统的原因之一。

就我目前的经验,以上理由可以充分打消在服务器上使用Arch Linux的想法。但是对于桌面系统,特别是对于开发人员,Arch还是相当不错的选择。

汝等虔诚的Arch教徒们,切勿忍耐;想安装什么的时候便装,想做什么研究的时候便做就好——因为明天并不见得还能正常运行。

本文转自d1net(转载)

时间: 2024-11-03 01:02:33

为什么Arch Linux不适合作为服务器操作系统的相关文章

操作系统-为什么说Windows系统是单用户伪多用户系统,不适合做服务器,而Linux则是真正的多用户

问题描述 为什么说Windows系统是单用户伪多用户系统,不适合做服务器,而Linux则是真正的多用户 为什么说Windows系统是单用户伪多用户系统,不适合做服务器,而Linux则是真正的多用户,求大神解答操作系统底层相关概念,谢谢 解决方案 Windows9x确实是伪多用户的,从win2000开始,Windows就是真正的多用户系统了,,你看的资料得有多老.至于说多用户的好处,就是安全啊,将服务器程序运行在低权限的用户上,就算黑客黑进来了也没有权限,只能想办法找系统漏洞提权再破坏系统啊

如何选择Linux服务器操作系统

Linux的发行版有上百种,如何选择也是一种难题.以下为收集的资料,仅供参考. 一.Ubuntu Desktop 和 Ubuntu Server 这个是最方便,也是最快捷的方式.如果刚开始使用Ubuntu,且不太熟悉命令行的可以选用Ubuntu Desktop来学习.继而转为Ubuntu Server.对于初学者,Ubuntu可以更好地上手,并且提供了很好提供了apt软件管理方式(这个是目前最好的软件管理方式),使用起来非常方便,同事Ubuntu的社区也非常的活跃,使用的人数也较多.遇到问题也可

广东Linux中心发布新支点服务器操作系统

近日,广东省LINUX公共服务http://www.aliyun.com/zixun/aggregation/12867.html">技术支持中心(简称广东省linux中心)面向中国政企用户的旗舰产品"新支点服务器操作系统"V4.02版本正式发布.它以能满足电信级操作系统所要求的高可靠性为最大亮点,成为现今国内许多政府部门.企事业单位出于对信息安全应用的考虑,而选择替换国外操作系统的一款知名产品.同时它也入选广东省政府以及许多名企的采购目录,足证其技术力量和产品品质已达

Linux系统下Apache服务器设置与优化

Apache服务器的设置文件位于/usr/local/apache/conf/目录下,传统上使用三个配置文件httpd.conf,access.conf和srm.conf,来配置Apache服务器的行为. httpd.conf提供了最基本的服务器配置,是对守护程序httpd如何运行的技术描述:srm.conf是服务器的资源映射文件,告诉服务器各种文件的MIME类型,以及如何支持这些文件:access.conf用于配置服务器的访问权限,控制不同用户和计算机的访问限制:这三个配置文件控制着服务器的各

CentOS 与 Ubuntu:哪个更适合做服务器?

已经决定买一台虚拟服务器,但还不能决定使用哪个 Linux 发行版?我们都经历过这种困扰.对于 Linux 发行版来说,要在这么多的发行版和种种支派flavors中选择一个,那简直能让人崩溃.不过,对于服务器而言,有两个主流的 Linux 发行版,那就是 CentOS 和 Ubuntu.但如何从这两个之中选择,这是摆在管理员.初学者和专业人士面前的主要问题.在对这两个(和更多)发行版有了一定的经验之后,我们决定对这两个发行版用于服务器时做个比较. 利益相关:本文译自 thishosting.ro

服务器操作系统应该选择 Debian/Ubuntu 还是 CentOS?

服务器操作系统应该选择 Debian/Ubuntu 还是 CentOS? 编辑推荐!本文来自知乎的袁昊洋,是我见过的关于如何选择服务器操作系统的最有理有据的文章,而且富有实践基础.小编基本上同意全文观点--当然,这并不是说大家就不应该选择其他的操作系统做服务器--甚至你选择Windows XP做服务器都有你的道理.大家有什么选择,希望也发表你的观点. 首先的首先,我想请各位玩家,你们不要自己最近新玩上什么就觉得什么好,然后大肆的推荐什么好不好!负点责任好不好!人家是服务器,有些时候选错一个发行版

在Ubuntu Linux上架设Web服务器详解

Apache 是一种功能强大的Web服务器.如今,Internet上无数运行在Linux上的Apache服务器正为Web世界的日益繁荣提供着有力的支撑.本文将向读者介绍如何在Ubuntu Linux系统迅速搭建Apache Web服务器. 尽管Ubuntu 是一种新兴的Linux分支,但Ubuntu 组织却为Apache提供了丰富的支持软件,这些软件都可以从发行版的光盘获取,也可以从官方站点轻松下载.所以,Ubuntu非常适合作为Web服务器的平台. 一. 安装Apache 下面,我们首先介绍如

如何在Linux下配置NFS服务器?

网络文件系统(NFS,Network File System)是一种将远程主机上的分区(目录)经网络挂载到本地系统的一种机制,通过对网络文件系统的支持,用户可以在本地系统上像操作本地分区一样来对远程主机的共享分区(目录)进行操作. 在嵌入式Linux 的开发过程中,开发者需要在Linux 服务器上进行所有的软件开发,交叉编译后,通用FTP 方式将可执行文件下载到嵌入式系统运行,但这种方式不但效率低下,且无法实现在线的调试.因此,可以通过建立NFS,把Linux 服务器上的特定分区共享到待调试的嵌

服务器操作系统大点兵系列之Windows篇

服务器的操作系统在商务活动的组织和实施过程中发挥着支配作用,选择合适的操作系统可以让硬件资 源更充分的得到利用,也可以让服务器利用更加安全高效,而错误的操作系统选择就可能导致企业的损失 .目前常见的服务器操作系统有WINDOWS.UNIX.LINUX和NETWARE几种,这几种服务器操作系统出自不同 的软件商,所面向的服务领域不同,在很多应用上也表现出较大的差异,如NetWare主要面向文件和打印 服务,Unix主要面向大型数据库.大批量数据处理等应用服务,用户在选择服务器操作系统时需要结合企