PRF:20180726 The evolution of package managers.md

@ davidchenliang 翻译的很好,个别地方发挥有些丢失原意。
This commit is contained in:
Xingyu.Wang 2018-08-18 16:07:08 +08:00
parent 15dd3438ed
commit 4fd05f3d7b

View File

@ -1,38 +1,39 @@
包管理器的进化
======
> 包管理器在 Linux 软件管理中扮演了重要角色。这里对一些主要的包管理器进行了对比。
![](https://opensource.com/sites/default/files/styles/image-full-size/public/lead-images/suitcase_container_bag.png?itok=q40lKCBY)
今天,每个可计算设备都会使用某种软件来完成预定的任务。在软件开发的上古时期,为了找出软件中的“虫”和其他缺陷,软件会被严格的测试。在近十年间,人们希望通过持续不断的安装新版本的软件来解决软件的缺陷问题,软件被通过互联网来频繁分发,而不是在软件尚未发布前进行过多的测试。在很多情况下,每个独立的应用软件都有其自带的更新器。而其一些软件则让用户自己去搞明白如何获取和升级软件。
今天,每个可计算设备都会使用某种软件来完成预定的任务。在软件开发的上古时期,为了找出软件中的“虫”和其它缺陷,软件会被严格的测试。在近十年间,软件被通过互联网来频繁分发,以试图通过持续不断的安装新版本的软件来解决软件的缺陷问题。在很多情况下,每个独立的应用软件都有其自带的更新器。而其一些软件则让用户自己去搞明白如何获取和升级软件。
Linux较早采用了维护一个中心化的软件仓库来发布软件更新这种做法,用户可以在这个软件仓库里查找并安装软件。在这篇文章里, 笔者将回顾在Linux上的如何进行软件安装的崎岖历史以及现代操作系统如何在软件安全漏洞不断被曝光中保持软件始终得到更新
Linux 较早采用了维护一个中心化的软件仓库来发布软件更新这种做法,用户可以在这个软件仓库里查找并安装软件。在这篇文章里, 笔者将回顾在 Linux 上的如何进行软件安装的历史,以及现代操作系统如何保持更新以应对[软件安全漏洞CVE][1]不断的曝光
### 那么在包管理器出现之前在Linux上是如何安装软件的呢
曾几何时软件都是通过FTP下载到本地或邮件列表译注即通过邮件列表发布源代码的补丁包来分发的最终这些发布方式在互联网的迅猛发展下都演化成为一个个现今常见的软件发布网站。通常几个小补丁文件会被压缩成一个Tar格式的包你需要做的是先解压这个包然后仔细阅读当中的README文件 如果你的系统上恰好有GCC译注GNU C Compiler或者其他厂商的C编译器的话你得首先运行./configure脚本并在脚本后添加相应的参数如库函数的路径创建可执行文件的路径等等除此之外configure脚本也会检查你操作系统上的软件依赖是否满足安装要求如果configure正常执行完毕一个Makefile文件将会被创建。
### 那么在包管理器出现之前在 Linux 上是如何安装软件的呢?
如果一个Makefile文件被成功创建 你就可以接下去执行make 命令这由你的编译器提供。make命令也有很多参数被称为make标识这些标识能帮助优化最终生成出来的二进制可执行文件。在计算机世界的早期这些优化是非常重要的因为彼时的计算机硬件正在为了跟上软件迅速的发展而疲于奔命。今日今时编译标识变得更加通用而不是为了优化哪些具体的硬件型号这得益于现代硬件和现代软件相比已经变得成本低廉唾手可得
曾几何时,软件都是通过 FTP 或邮件列表LCTT 译注:即通过邮件列表发布源代码的补丁包)来分发的(最终这些发布方式在互联网的迅猛发展下都演化成为一个个现今常见的软件发布网站)。(一般在一个 tar 文件中)只有一个非常小的文件包含了创建二进制的说明。你需要做的是先解压这个包,然后仔细阅读当中的 `README` 文件, 如果你的系统上恰好有 GCCLCTT 译注GNU C Compiler或者其它厂商的 C 编译器的话,你得首先运行 `./configure` 脚本,并在脚本后添加相应的参数,如库函数的路径、创建可执行文件的路径等等。除此之外,这个配置过程也会检查你操作系统上的软件依赖是否满足安装要求。如果缺失了任何主要的依赖,该配置脚本会退出不再继续安装,直到你满足了该依赖。如果该配置脚本正常执行完毕,将会创建一个 `Makefile` 文件
当有了一个 `Makefile` 文件时, 你就可以接下去执行 `make` 命令(该命令由你所使用的编译器提供)。`make` 命令也有很多参数,被称为 `make` <ruby>标识<rt>flag</rt></ruby>,这些标识能为你的系统优化最终生成出来的二进制可执行文件。在计算机世界的早期,这些优化是非常重要的,因为彼时的计算机硬件正在为了跟上软件迅速的发展而疲于奔命。今日今时,编译标识变得更加通用而不是为了优化哪些具体的硬件型号,这得益于现代硬件和现代软件相比已经变得成本低廉,唾手可得。
最后,在 `make` 完成之后, 你需要运行 `make install` (或 `sudo make install`LCTT 译注:依赖于你的用户权限) 来“真正”将这个软件安装到你的系统上。可以想象为你系统上的每一个软件都执行上述的流程将是多么无聊费时更不用说如果更新一个已经安装的软件将会多复杂多么需要精力投入。LCTT 译注:上述流程也称 CMMI 安装, 即Configure、Make、Make Install
最后在make 完成之后, 你需要运行'make install'(或'sudo make install')(译注:依赖于你的用户权限) 来‘真正’将这个软件安装到你的系统上。可以想象,为你系统上的每一个软件都执行上述的流程将是多么无聊费时,更不用说如果更新一个已经安装的软件将会多复杂,多么需要精力投入。
译注上述流程也称CMMI安装 即Configure Make Make Install
### 那么软件包是什么?
’软件包‘(译注:下文简称包)这个概念是用来解决在软件安装升级过程中的复杂性的。包将软件安装升级中需要的多个数据文件合并成一个单独的文件,这将极大的提高可移植性和减小存储空间(译注:减少存储空间这一点在现在已经不再重要),包中的二进制可执行文件已经预先用安装开发者所选择的编译标识预编译。包本身包括了所有需要的元数据,如软件的名字,软件的说明,版本号,以及要运行这个软件所需要的依赖包等等。
<ruby>软件包<rt>package</rt></ruby>LCTT 译注:下文简称“包”)这个概念是用来解决在软件安装、升级过程中的复杂性的。包将软件安装升级中需要的多个数据文件合并成一个单独的文件,这将便于传输和通过压缩文件来减小存储空间LCTT 译注:减少存储空间这一点在现在已经不再重要),包中的二进制可执行文件已根据开发者所选择的编译标识预编译。包本身包括了所有需要的元数据,如软件的名字、软件的说明、版本号,以及要运行这个软件所需要的依赖包等等。
各个不同的Linux发行版都创造了他们自己的包格式其中做常用的包格式有:
不同流派的 Linux 发行版都创造了它们自己的包格式,其中最常用的包格式有:
* .deb: 这种包格式由Debian Ubuntu Linux Mint以及其他的变种使用。这是最早被发明的包类型。
* .rpm: 这种包格式源自红帽子包管理器(译注: 取自英文的首字母。使用这种包的Linux发行版有Red Hat, Fedora, SUSE以及其他一些较小的发行版。
* .tar.xz: 这种包格式只是一个软件压缩包而已Arch Linux使用这种发行版中立的格式来安装软件
* .deb:这种包格式由 Debian、Ubuntu、Linux Mint 以及其它的变种使用。这是最早被发明的包类型。
* .rpm:这种包格式最初被称作<ruby>红帽包管理器<rt>Red Hat Package Manager</rt></ruby>LCTT 译注: 取自英文的首字母)。使用这种包的 Linux 发行版有 Red Hat、Fedora、SUSE 以及其它一些较小的发行版。
* .tar.xz这种包格式只是一个软件压缩包而已,这是 Arch Linux使用的格式。LCTT 译注:这种格式无需特别的包管理器,解压即可)
尽管上述的包格式自身并不能管理软件的依赖问题但是他们的出现将Linux软件包管理向前推进了一大步。
尽管上述的包格式自身并不能直接管理软件的依赖问题,但是它们的出现将 Linux 软件包管理向前推进了一大步。
### 软件仓库到底是什么?
多年以前当智能电话还没有像现在这样流行时非Linux世界的用户是很难理解软件仓库的概念的。甚至今时今日大多数完全工作在Windows下的用户还是习惯于打开浏览器搜索要安装的软件或升级包下载然后安装。但是智能电话传播了软件’商店’(译注: 对应Linux里的软件仓库这样一个概念。智能电话用户获取软件和包管理器的工作方式已经非常相近了。些许不同的是尽管大多数软件商店还在费力美化它的图形界面来吸引用户大多数Linux用户还是愿意使用命令行来安装软件。总而言之软件仓库是一个中心化的可安装软件列表上面列举了在当前系统中预先配置好的软件仓库里所有可以安装的软件。下面我们举一些例子来说在各个不同的Linux发行版下如何在对应的软件仓库里搜寻某个特定的软件。
多年以前(当智能电话还没有像现在这样流行时),非 Linux 世界的用户是很难理解软件仓库的概念的。甚至今时今日,大多数完全工作在 Windows 下的用户还是习惯于打开浏览器,搜索要安装的软件(或升级包),下载然后安装。但是,智能电话传播了软件“商店”LCTT 译注: 对应 Linux 里的软件仓库)这样一个概念。智能电话用户获取软件的方式和包管理器的工作方式已经非常相近了。些许不同的是,尽管大多数软件商店还在费力美化它的图形界面来吸引用户,大多数 Linux 用户还是愿意使用命令行来安装软件。总而言之,软件仓库是一个中心化的可安装软件列表,上面列举了在当前系统中预先配置好的软件仓库里所有可以安装的软件。下面我们举一些例子来说在各个不同的 Linux 发行版下如何在对应的软件仓库里搜寻某个特定的软件(输出有截断)
在Arch Linux下使用aurman
Arch Linux 下使用 `aurman`
```
user@arch ~ $  aurman -Ss kate
@ -45,7 +46,7 @@ aur/kate-git r15288.15d26a7-1 (1, 1e-06)
    An advanced editor component which is used in numerous KDE applications requiring a text editing component
```
CentOS 7下使用 YUM
CentOS 7 下使用 `yum`
```
[user@centos ~]$ yum search kate
@ -56,7 +57,7 @@ kate-part.x86_64 : Kate kpart plugin
```
Ubuntu下使用APT
Ubuntu 下使用 `apt`
```
user@ubuntu ~ $ apt search kate
@ -78,19 +79,19 @@ kate5-data/xenial,xenial 4:15.12.3-0ubuntu2 all
### 最好用的包管理器有哪些?
如上示例的输出,包管理器用来和相应的软件仓库交互,获取软件的相应信息。下面对们做一个简短介绍。
如上示例的输出,包管理器用来和相应的软件仓库交互,获取软件的相应信息。下面对们做一个简短介绍。
### 基于PRM包格式的包管理器
#### 基于 PRM 包格式的包管理器
更新基于RPM的系统特别是那些基于Red Hat技术的系统有着非常有趣而又详细的历史。实际上现在的[YUM][2]版本(企业级发布版)和[DNF][3](社区版)就融合了好几个开源项目来提供他们现在的功能。
更新基于 RPM 的系统,特别是那些基于 Red Hat 技术的系统,有着非常有趣而又详实的历史。实际上,现在的 [YUM][2] 版本(用于 企业级发行版)和 [DNF][3](用于社区版)就融合了好几个开源项目来提供它们现在的功能。
Red Hat最初使用的包管理器,即[RPM][4](红帽包管理器)今时今日还在广泛使用着。不过它的主要作用是安装本地的RPM包而不是去在软件仓库搜索软件。一个叫'up2date'的包管理器被开发出来,它被用来通知用户包的最新更新,还能让用户在远程仓库里搜索软件并便捷的安装软件的依赖。尽管这个包管理器尽职尽责,一些社区成员还是感觉'up2date'有着明显的不足。
Red Hat 最初使用的包管理器,被称为 [RPM][4]<ruby>红帽包管理器<rt>Red Hat Package Manager</rt></ruby>),时至今日还在使用着。不过,它的主要作用是安装本地的 RPM 包,而不是去在软件仓库搜索软件。后来开发了一个叫 `up2date` 的包管理器,它被用来通知用户包的最新更新,还能让用户在远程仓库里搜索软件并便捷的安装软件的依赖。尽管这个包管理器尽职尽责,但一些社区成员还是感觉 `up2date` 有着明显的不足。
现在的YUM来自于好几个不同社区的努力。1999-2001年一群在Terra Soft Solution的伙计们开发了黄狗更新器YUP将其作为[Yellow Dog Linux][5]图形安装器的后端。杜克大学喜欢这个主意就决定去增强它的功能,他们开发了[黄狗更新器--修改版(YUM)][16]这最终被用来帮助管理杜克大学的Red Hat系统。Yum壮大的很快到2005年它已经被超过一半的Linux市场所采用。今日几乎所有的使用RPM的的Linux都会使用YUM来进行包管理(当然也有一些例外)。
现在的 YUM 来自于好几个不同社区的努力。1999-2001 年一群在 Terra Soft Solution 的伙计们开发了<ruby>黄狗更新器<rt>Yellowdog Updater</rt></ruby>YUP将其作为 [Yellow Dog Linux][5] 图形安装器的后端。<ruby>杜克大学<rt>Duke University</rt></ruby>喜欢这个主意就决定去增强它的功能,它们开发了<ruby>[黄狗更新器--修改版][16]<rt>Yellowdog Updater, Modified</rt></ruby>YUM这最终被用来帮助管理杜克大学的 Red Hat 系统。Yum 壮大的很快,到 2005 年,它已经被超过一半的 Linux 市场所采用。今日,几乎所有的使用 RPM 的的 Linux 都会使用 YUM 来进行包管理(当然也有一些例外)。
### 使用YUM
##### 使用 YUM
为了能让YUM正常工作比如从一个软件仓库里下载和安装包仓库说明文件必须放在/etc/yum.repos.d/目录下且必须以'.repo'作为扩展名。如下是repo文件的内容:
为了能让 YUM 正常工作,比如从一个软件仓库里下载和安装包,仓库说明文件必须放在 `/etc/yum.repos.d/` 目录下且必须以 `.repo` 作为扩展名。如下是一个示例文件的内容:
```
[local_base]
@ -100,10 +101,9 @@ enabled=1
gpgcheck=0
```
这是笔者本地仓库之一,这也是为什么gpgcheck值为零的原因。如果这个值为1的话每个包都需要被秘钥签名相应的秘钥也要导入到安装软件的系统上。因为这个软件仓库是笔者本人维护的且笔者信任这个仓库里的包,所以就不去对们一一签名了。
这是笔者本地仓库之一,这也是为什么 gpgcheck 值为 0 的原因。如果这个值为 1 的话,每个包都需要被密钥签名,相应的密钥(的公钥)也要导入到安装软件的系统上。因为这个软件仓库是笔者本人维护的且笔者信任这个仓库里的包,所以就不去对们一一签名了。
当一个仓库文件准备好时,你就能开始从远程软件仓库开始安装文件了。最基本的命令是'yum update',这将会更新所有已安装的包。你也不需要用特殊的命令来更新仓库本身,所有这一切都已自动完成了。运行命令示例如下:
当一个仓库文件准备好时,你就能开始从远程软件仓库开始安装文件了。最基本的命令是 `yum update`,这将会更新所有已安装的包。你也不需要用特殊的命令来更新仓库本身,所有这一切都已自动完成了。运行命令示例如下:
```
[user@centos ~]$ sudo yum update
@ -126,10 +126,9 @@ Resolving Dependencies
--> Running transaction check
```
如果你确定想让YUM在执行任何命令时不要停下来等待用户输入你可以命令里放-y标志如'yum update -y'
如果你确定想让 YUM 在执行任何命令时不要停下来等待用户输入,你可以命令里放 `-y` 标志,如 `yum update -y`
安装一个新包很简单。首先,用'yum search'搜索包的名字。
安装一个新包很简单。首先,用 `yum search` 搜索包的名字。
```
[user@centos ~]$ yum search kate
@ -143,9 +142,9 @@ kate-libs.x86_64 : Runtime files for kate
kate-part.i686 : Kate kpart plugin
```
当你找到你要安装的包后,你可以用sudo yum install kate-devel -y来安装。如果你安装了你不需要的软件可以用sudo yum remove kdate-devel -y来从系统上删除它默认情况下YUM会删除软件包以及它的依赖。
当你找到你要安装的包后,你可以用 `sudo yum install kate-devel -y` 来安装。如果你安装了你不需要的软件,可以用 `sudo yum remove kdate-devel -y` 来从系统上删除它默认情况下YUM 会删除软件包以及它的依赖。
有些时候你甚至都不清楚要安装的包的名称,你只知道某个实用程序的名字。(译注:可以理解实用程序是安装包的子集)。例如,你想找实用程序updatedb(它是用来创建/更新由locate命令创建的数据库的),直接试图安装'updatedb'会返回下面的结果:
有些时候你甚至都不清楚要安装的包的名称,你只知道某个实用程序的名字。(LCTT 译注:可以理解实用程序是安装包的子集)。例如,你想找实用程序 `updatedb`(它是用来创建/更新由 `locate` 命令所使用的数据库的),直接试图安装 `updatedb` 会返回下面的结果:
```
[user@centos ~]$ sudo yum install updatedb
@ -173,17 +172,17 @@ Matched from:
Filename    : /usr/bin/updatedb
```
笔者使用星号的原因是'yum whatprovides'使用路径去匹配文件。笔者不确定文件在哪里,所以使用星号去指代任意路径。
笔者在前面使用星号的原因是 `yum whatprovides` 使用路径去匹配文件。笔者不确定文件在哪里,所以使用星号去指代任意路径。
当然YUM还有很多其他的可选项。这里笔者希望你能够自己查看YUM的手册来找到其他额外的可选额
当然 YUM 还有很多其它的可选项。这里笔者希望你能够自己查看 YUM 的手册来找到其它额外的可选项
[Dandified Yum (DNF)][7]是YUM的下一代接班人。从Fedora 18开始被作为包管理器引入系统不过它并没有被企业版所采用所以它只在Fedora以及变种上占据了主导地位。DNF的用法和YUM几乎一模一样它主要是用来解决性能问题晦涩无说明的API缓慢的依赖解析以及偶尔的高内存占用。DNF是作为YUM的直接替代品来开发的,因此这里笔者就不重复它的用法了,你只用简单的将YUM替换为DNF就行了。
<ruby>[时髦的 Yum][7]<rt>Dandified Yum</rt></ruby>DNF是 YUM 的下一代接班人。从 Fedora 18 开始被作为包管理器引入系统,不过它并没有被企业版所采用,所以它只在 Fedora以及变种上占据了主导地位。DNF 的用法和 YUM 几乎一模一样,它主要是用来解决性能问题、晦涩无说明的API、缓慢/不可靠的依赖解析以及偶尔的高内存占用。DNF 是作为 YUM 的直接替代品来开发的,因此这里笔者就不重复它的用法了,你只用简单的将 `yum` 替换为 `dnf` 就行了。
###使用Zypper
##### 使用 Zypper
[Zypper][8]是用来管理RPM包的另外一个包管理器。这个包管理器主要用于[SUSE][9](和[openSUSE][10],在[MeeGo][11],[Sailfish OS][12],[Tizen][13]上也有使用。它在2006年被开发出来也已经经过了多次迭代发布。除了作为[YaST][14]的系统管理工具和有些用户认为它比YUM要快之外也没有什么好多说的。
[Zypper][8] 是用来管理 RPM 包的另外一个包管理器。这个包管理器主要用于 [SUSE][9](和 [openSUSE][10]),在[MeeGo][11]、[Sailfish OS][12]、[Tizen][13] 上也有使用。它最初开发于 2006 年,已经经过了多次迭代。除了作为系统管理工具 [YaST][14] 的后端和有些用户认为它比 YUM 要快之外也没有什么好多说的。
Zypper's使用与YUM非常相像。它被用来搜索更新安装和删除包请使用如下命令
Zypper 使用与 YUM 非常相像。它被用来搜索、更新、安装和删除包,简单的使用命令如下
```
zypper search kate
@ -192,7 +191,7 @@ zypper install kate
zypper remove kate
```
使用Zypper的系统在添加软件仓库的方面的做法上有些许不同与上述讨论的包管理器不同zypper使用包管理器本身来添加软件仓库。最通用的方法是通过一个URL但是Zypper也支持从仓库文件里导入。
主要的不同来自于使用 Zypper 的系统在添加软件仓库的做法上Zypper 使用包管理器本身来添加软件仓库。最通用的方法是通过一个 URL但是 Zypper 也支持从仓库文件里导入。
```
suse:~ # zypper addrepo http://download.videolan.org/pub/vlc/SuSE/15.0 vlc
@ -214,7 +213,7 @@ Removing repository 'vlc' ...................................[done]
Repository 'vlc' has been removed.
```
使用'zypper repos'命令来查看当前系统上的软件仓库的状态:
使用 `zypper repos` 命令来查看当前系统上的软件仓库的状态:
```
suse:~ # zypper repos
@ -230,7 +229,7 @@ Repository priorities are without effect. All enabled repositories share the sam
 6 | repo-oss                  | openSUSE-Leap-15.0-Oss                  | Yes     | ( p) Yes  | Yes    
```
'zypper'甚至还有和YUM相同的功能:搜索包存在哪个实用程序。和YUM有所不同的是它在命令行里使用破折号但是这个搜索方法现在被废除了...
`zypper` 甚至还有和 YUM 相同的功能:搜索包含文件或二进制的包。和 YUM 有所不同的是,它在命令行里使用破折号(但是这个搜索方法现在被废除了……
```
localhost:~ # zypper what-provides kate
@ -245,30 +244,28 @@ i+ | Kate | Advanced Text Editor | application
i  | kate | Advanced Text Editor | package  
```
YUMDNF和Zypper三剑客拥有的功能比在这篇小文里讨论的要多得多,请查看官方文档来得到更深入的信息。
YUM、DNF 和 Zypper 三剑客拥有的功能比在这篇小文里讨论的要多得多,请查看官方文档来得到更深入的信息。
###基于Debian 的包管理器
#### 基于 Debian 的包管理器
作为一个现今仍在被积极维护的历史悠久的Linux发布版本Debian的包管理系统和基于RPM的系统的包管理系统非常类似。它使用扩展名为.deb的包这种文件能被一个叫做dpkg的工具所管理。dpgk同RPM非常相似,它被设计成用来管理在存在于本地(硬盘)的包。它不会去做包依赖关系解析(它会做依赖关系检查,不过仅此而已),而且在同远程软件仓库交互上也并无可靠的途径为了提高用户体验并便于使用Debian项目开始了一个软件项目Deity,最终这个代号被丢弃并改成了现在的[Advanced Pack Tool(APT)][15]
作为一个现今仍在被积极维护的最古老的 Linux 发行版之一Debian 的包管理系统和基于 RPM 的系统的包管理系统非常类似。它使用扩展名为 “.deb” 的包,这种文件能被一个叫做 `dpkg` 的工具所管理。`dpgk` 同 `rpm` 非常相似,它被设计成用来管理在存在于本地(硬盘)的包。它不会去做包依赖关系解析(它会做依赖关系检查,不过仅此而已),而且在同远程软件仓库交互上也并无可靠的途径。为了提高用户体验并便于使用Debian 项目开始了一个软件项目Deity最终这个代号被丢弃并改成了现在的 <ruby>[高级打包工具][15]<rt>Advanced Pack Tool</rt></ruby>APT
1998年APT测试版本发布甚至早于1999年的Debian 2.1正式版发布许多用户认为APT是基于Debian系统的默认包管理器。APT使用了和RPM一样的风格来管理不过和YUM使用单独的.repo不同apt曾经使用/etc/apt/sources.list文件来管理软件仓库后来的变成也可以使用/etc/apt/sources.d目录来管理。如同基于RPM的系统一样你也有很多很多选项配置来完成同样的事情。你可以编辑/创建前述的文件或者使用图形界面来完成上述工作如Ubuntu的Software & Updates为了给所有的Linux发行版统一的待遇,笔者将会只介绍命令行的选项。
要想不直接编辑文件内容而直接增加软件仓库的话,用如下命令:
1998 年APT 测试版本发布(甚至早于 1999 年的 Debian 2.1 发布),许多用户认为 APT 是基于 Debian 系统标配功能之一。APT 使用了和 RPM 一样的风格来管理仓库,不过和 YUM 使用单独的 .repo 文件不同APT 曾经使用 `/etc/apt/sources.list` 文件来管理软件仓库,后来的变成也可以使用 `/etc/apt/sources.d` 目录来管理。如同基于 RPM 的系统一样,你也有很多很多选项配置来完成同样的事情。你可以编辑和创建前述的文件,或者使用图形界面来完成上述工作(如 Ubuntu 的“Software & Updates”为了给所有的 Linux 发行版统一的待遇,笔者将会只介绍命令行的选项。
要想不直接编辑文件内容而直接增加软件仓库的话,可以用如下命令:
```
user@ubuntu:~$ sudo apt-add-repository "deb http://APT.spideroak.com/ubuntu-spideroak-hardy/ release restricted"
```
这个命令将会在/etc/apt/sources.list.d目录里创建一个spideroakone.list文件。显而易见文件里的内容依赖于所添加的软件仓库如果你想加一个个人软件包存档的话译注PPA,你可以用如下的办法:
这个命令将会在 `/etc/apt/sources.list.d` 目录里创建一个 `spideroakone.list` 文件。显而易见,文件里的内容依赖于所添加的软件仓库,如果你想加一个<ruby>个人软件包存档<rt>Personal Package Archive</rt></ruby>PPA的话,你可以用如下的办法:
```
user@ubuntu:~$ sudo apt-add-repository ppa:gnome-desktop
```
注意: Debian并不支持本地PPAs
注意: Debian 原生并不支持本地 PPA
在添加了一个软件仓库后需要通知Debian有一个新的仓库可以用来搜索包可以运行apt-get update来完成。
在添加了一个软件仓库后,需要通知基于 Debian 的系统有一个新的仓库可以用来搜索包,可以运行 `apt-get update` 来完成:
```
user@ubuntu:~$ sudo apt-get update
@ -285,7 +282,7 @@ Fetched 6,399 kB in 3s (2,017 kB/s)                              
Reading package lists... Done
```
现在新的软件仓库已经在你的系统里安装并更新好了,你可以用apt-cache来搜索你想要的包了。
现在新的软件仓库已经在你的系统里安装并更新好了,你可以用 `apt-cache` 来搜索你想要的包了。
```
user@ubuntu:~$ apt-cache search kate
@ -299,38 +296,36 @@ kate-dbg - debugging symbols for Kate
katepart - embeddable text editor component
```
要安装kate,简单的运行下面的命令:
要安装 kate简单的运行下面的命令:
```
user@ubuntu:~$ sudo apt-get install kate
```
To remove a package, use `apt-get remove`:
要是删除一个包,使用 `apt-get remove`
```
user@ubuntu:~$ sudo apt-get remove kate
```
APT并没有提供一个类似于'yum whatprovides'的功能,如果你想深入包内部去确定一个特定的文件的话,也有一些别的方法能帮你完成这个目标,
要探索一个包的话APT 并没有提供一个类似于 `yum whatprovides` 的功能,如果你想深入包内部去确定一个特定的文件的话,也有一些别的方法能帮你完成这个目标,
如: 用dpkg
如: 用 `dpkg`
```
user@ubuntu:~$ dpkg -S /bin/ls
coreutils: /bin/ls
```
或者: apt-file
或者: `apt-file`
```
user@ubuntu:~$ sudo apt-get install apt-file -y
user@ubuntu:~$ sudo apt-file update
user@ubuntu:~$ apt-file search kate
```
'apt-file search'的问题是和yum whatprovides不同因为自动添加了通配符搜索而输出过于详细在结果里包括了所有包含有kate的结果。
`yum whatprovides` 不同的是,`apt-file search` 的问题是因为自动添加了通配符搜索而输出过于详细(除非你知道确切的路径),最终在结果里包括了所有包含有 “kate” 的结果。
```
kate: /usr/bin/kate
@ -340,17 +335,18 @@ kate: /usr/lib/x86_64-linux-gnu/qt5/plugins/ktexteditor/katecloseexceptplugin.so
kate: /usr/lib/x86_64-linux-gnu/qt5/plugins/ktexteditor/katectagsplugin.so
```
上面这些例子大部分都使用了apt-get.请注意现今大多数的Ubuntu教程里都径直使用了'apt'. 单独一个apt是用来实现最常用的那些APT命令的。APT看上去是用来整合那些被分散在'apt-get','apt-cache'以及其他一些命令的的功能的。它还加上了一些额外的改进如色彩进度条以及其他一些小功能。上述的常用apt功能都能被apt替代但是并不是所有的基于Debian的系统都能使用apt接受安全包补丁的,你有可能要安装额外的包的实现上述功能。
上面这些例子大部分都使用了 `apt-get`。请注意现今大多数的 Ubuntu 教程里都径直使用了 `apt`。 单独一个 `apt` 设计用来实现那些最常用的 APT 命令的。`apt` 命令看上去是用来整合那些被分散在 `apt-get`、`apt-cache` 以及其它一些命令的的功能的。它还加上了一些额外的改进,如色彩、进度条以及其它一些小功能。上述的常用命令都能被 `apt` 替代,但是并不是所有的基于 Debian 的系统都能使用 `apt` 接受安全包补丁的,你有可能要安装额外的包的实现上述功能。
###基于Arch的包管理器
#### 基于 Arch 的包管理器
[Arch Linux][16]使用称为[packman][17]的包管理器。和‘.deb以及'.rpm不同它使用更为传统的压缩包形式'.tar.xz'。这帮助Arch Linux包能够使用更小的包尺寸。自从2002年发布以来pacman一直在稳定发布和改善。使用它最大的好处之一是他支持[Arch Build System][18],一个从源代码级别构建包的构建系统。这个构建系统使用一个叫PKGBUILD的文件这个文件包含了如版本号发布号依赖等等的元数据以及为编译一个遵守Arch Linux需求的包所需要的带有必须编译选项的脚本。而编译的结果就是前文所提的被pacman所使用的.tar.xz的文件。
[Arch Linux][16] 使用称为 [packman][17] 的包管理器。和 .deb 以及 .rpm 不同,它使用更为传统的 LZMA2 压缩包形式 .tar.xz 。这可以使 Arch Linux 包能够比其它形式的压缩包(如 gzip有更小的尺寸。自从 2002 年首次发布以来, `pacman` 一直在稳定发布和改善。使用它最大的好处之一是它支持 [Arch Build System][18],这是一个从源代码级别构建包的构建系统。该构建系统借助一个叫 `PKGBUILD` 的文件,这个文件包含了如版本号、发布号、依赖等等的元数据,以及一个为编译遵守 Arch Linux 需求的包所需要的带有必要的编译选项的脚本。而编译的结果就是前文所提的被 `pacman` 所使用的 .tar.xz 的文件。
上述的这套系统技术上导致了[Arch User Respository][19](AUR)的产生这是一个社区驱动的软件仓库仓库里包括有PKGBUILD文件以及支持的补丁包或脚本。这给Arch Linux带了无穷无尽的软件资源。最为明显的好处是如果一个用户或开发者希望他开发的软件能被广大公众所使用他不必通过官方途径去在主流软件仓库获得许可。而不利之处则是它必须将依赖社区的流程类似于[Docker Hub][20]Canonical's Snap Packages(译注: Canonical是Ubuntu的发行公司)或者其他相似的机制。有很多特定于AUR的包管理器能被用来从ARU里的PGKBUILD文件下载编译安装下面我们来仔细看看怎么做。
上述的这套系统技术上导致了 <ruby>[Arch 用户仓库][19]<rt>Arch User Respository</rt></ruby>AUR的产生这是一个社区驱动的软件仓库仓库里包括有 `PKGBUILD` 文件以及支持补丁或脚本。这给 Arch Linux 带了无穷无尽的软件资源。最为明显的好处是如果一个用户(或开发者)希望他开发的软件能被广大公众所使用,他不必通过官方途径去在主流软件仓库获得许可。而不利之处则是它必须将依赖社区的流程,类似于 [Docker Hub][20]、
Canonical 的 Snap PackagesLCTT 译注: Canonical 是 Ubuntu 的发行公司),或者其它类似的机制。有很多特定于 AUR 的包管理器能被用来从 AUR 里的 `PGKBUILD` 文件下载、编译、安装,下面我们来仔细看看怎么做。
###使用pacman和官方软件仓库
##### 使用 pacman 和官方软件仓库
Arch的主要包管理器pacman使用标识位而不是像yumapt一样使用命令词。例如要搜索一个包你要用'pacman -Ss'。和Linux上别的命令一样你可以找到pacman 的manpage和在线帮助。pacman大多数的命令都使用了同步(-S)这个标识位。例如:
Arch 的主要包管理器:`pacman`,使用标识位而不是像 `yum``apt` 一样使用命令词。例如,要搜索一个包,你要用 `pacman -Ss` 。和 Linux 上别的命令一样,你可以找到 pacman 的手册页和在线帮助。`pacman` 大多数的命令都使用了同步(`-S`这个标识位。例如:
```
user@arch ~ $ pacman -Ss kate
@ -367,7 +363,7 @@ community/haskell-cheapskate 0.1.1-100
    Experimental markdown processor.
```
Arch也使用和别的包管理器类似的软件仓库。在上面的输出中搜索结果前面有标明它是从哪个仓库里搜索到的这里是'extra/'和community/。同Red Hat和Debian系统一样Arch依靠用户将软件仓库的信息加入到一个特定的文件里:/etc/pacman.conf。下面的例子非常接近一个仓库系统。笔者还打开了'[multilib]'仓库来支持Steam:
Arch 也使用和别的包管理器类似的软件仓库。在上面的输出中,搜索结果前面有标明它是从哪个仓库里搜索到的(这里是 `extra/``community/`)。同 Red Hat 和 Debian 系统一样Arch 依靠用户将软件仓库的信息加入到一个特定的文件里:`/etc/pacman.conf`。下面的例子非常接近一个仓库系统。笔者还打开了 `[multilib]` 仓库来支持 Steam
```
[options]
@ -392,14 +388,14 @@ Include = /etc/pacman.d/mirrorlist
Include = /etc/pacman.d/mirrorlist
```
你也可以指定在pacman.conf里指定具体的URL。这个功能可以用来确定在某一时刻所有的包来自一个确定的地方,比如,如果一个安装包存在严重的功能缺陷并且很不幸它恰好还有几个包依赖,你能及时回滚到一个安全点,如果你已经在pacman.conf里加入了具体的URL的话,你就用用这个命令降级你的系统。
你也可以`pacman.conf` 里指定具体的 URL。这个功能可以用来确保在某一时刻所有的包来自一个确定的地方,比如,如果一个安装包存在严重的功能缺陷并且很不幸它恰好还有几个包依赖,你能及时回滚到一个安全点,如果你已经在 `pacman.conf` 里加入了具体的 URL 的话,你就用用这个命令降级你的系统。
```
[core]
Server=https://archive.archlinux.org/repos/2017/12/22/$repo/os/$arch
```
和Debian系统一样Arch并不会自动更新它的本地仓库。你可以用下面的命令来刷新包管理器的数据库
Debian 系统一样Arch 并不会自动更新它的本地仓库。你可以用下面的命令来刷新包管理器的数据库:
```
user@arch ~ $ sudo pacman -Sy
@ -411,7 +407,7 @@ user@arch ~ $ sudo pacman -Sy
 multilib is up to date
```
你可以看到在上述的输出中,'pacman'认为multilib包数据库是更新到最新状态的。如果你认为这个结果不正确的话,你可以强制运行刷新:pacman -Syy。如果你想升级你的整个系统的话不包括从AUR安装的包你可以运行pacman -Syu:
你可以看到在上述的输出中,`pacman` 认为 multilib 包数据库是更新到最新状态的。如果你认为这个结果不正确的话,你可以强制运行刷新`pacman -Syy`。如果你想升级你的整个系统的话(不包括从 AUR 安装的包),你可以运行 `pacman -Syu`
```
user@arch ~ $ sudo pacman -Syu
@ -438,9 +434,9 @@ Net Upgrade Size:      -365.27 MiB
:: Proceed with installation? [Y/n]
```
在前面提到的降级系统的情景中,你可以运行pacman -Syyuu来强行降级系统。你必须重视这一点:虽然在大多数情况下这不会引起问题,但是这种可能性还是存在,即降级一个包或几个包将会引起级联传播的失败并会将你的系统处于不一致的状态(译注:即系统进入无法正常使用的状态),请务必小心!
在前面提到的降级系统的情景中,你可以运行 `pacman -Syyuu` 来强行降级系统。你必须重视这一点:虽然在大多数情况下这不会引起问题,但是这种可能性还是存在,即降级一个包或几个包将会引起级联传播的失败并会将你的系统处于不一致的状态(LCTT 译注:即系统进入无法正常使用的状态),请务必小心!
运行pacman -S kate来安装一个包。
运行 `pacman -S kate` 来安装一个包。
```
user@arch ~ $ sudo pacman -S kate
@ -457,7 +453,7 @@ Total Installed Size:  38.91 MiB
:: Proceed with installation? [Y/n]
```
你可以运行pacman -R kate来删除一个包。这将会只删除这个包自身而不会去删除它的依赖包。
你可以运行 `pacman -R kate` 来删除一个包。这将会只删除这个包自身而不会去删除它的依赖包。
```
user@arch ~ $ sudo pacman -S kate
@ -471,7 +467,7 @@ Total Removed Size:  20.30 MiB
:: Do you want to remove these packages? [Y/n]
```
如果你想删除没有被其他包依赖的包你可以运行pacman -Rs:
如果你想删除没有被其它包依赖的包,你可以运行 `pacman -Rs`
```
user@arch ~ $ sudo pacman -Rs kate
@ -486,7 +482,7 @@ Total Removed Size:  38.91 MiB
:: Do you want to remove these packages? [Y/n]
```
在笔者看来Pacman是搜索一个指定实用程序中的指定包的最齐全的工具。如上所示,'YUM'和'APT'都依赖硬编码路径去搜索到有用的结果而Pacman则做了一些智能的猜测,它会去猜测你最有可能想搜索的包。
在笔者看来Pacman 是搜索一个指定实用程序中的包名的最齐全的工具。如上所示YUM 和 APT 都依赖于‘路径’去搜索到有用的结果,而 Pacman 则做了一些智能的猜测,它会去猜测你最有可能想搜索的包。
```
user@arch ~ $ sudo pacman -Fs updatedb
@ -498,9 +494,9 @@ extra/kate 18.04.2-2
    usr/bin/kate
```
###使用AUR
##### 使用 AUR
有很多流行的AUR包管理器助手。其中'yaourt' 和'pacaur' 颇为流行。不过,这两个项目已经被列为不继续开发以及有已知的问题未解决[Arch Wiki][21]。因为这个原因这里直接讨论aurman除了会搜索AUR以及包含几个有帮助的其实很危险的选项之外它的工作机制和'pacman'极其类似。从AUR安装一个包将会初始化包维护者的构建脚本。你将会被要求输入几次授权以便让程序继续进行下去(为了简短起见,笔者截断了输出)。
有很多流行的 AUR 包管理器助手。其中 `yaourt``pacaur` 颇为流行。不过,这两个项目已经被 [Arch Wiki][21] 列为“不继续开发以及有已知的问题未解决”。因为这个原因,这里直接讨论 `aurman`,除了会搜索 AUR 以及包含几个有帮助的(其实很危险)的选项之外,它的工作机制和 `pacman` 极其类似。从 AUR 安装一个包将会初始化包维护者的构建脚本。你将会被要求输入几次授权以便让程序继续进行下去(为了简短起见,笔者截断了输出)。
```
aurman -S telegram-desktop-bin
@ -542,16 +538,16 @@ Net Upgrade Size:       5.33 MiB
:: Proceed with installation? [Y/n]
```
依照你所安装的包的复杂性程度的高低,有时你将会被要求给出进一步的输入确定,为了避免这些反复的输入,'aurman' 允许你使用'--noconfirm'和'--noedit'选项。这相当于说‘接受所有的预定设置,并相信包管理器不会干坏事。**使用这两个选项时请务必小心!!**,虽然这些选项本身不太会破坏你的系统,你也不能盲目的接受他人的脚本程序。
依照你所安装的包的复杂性程度的高低,有时你将会被要求给出进一步的输入,为了避免这些反复的输入,`aurman` 允许你使用 `--noconfirm``--noedit` 选项。这相当于说“接受所有的预定设置,并相信包管理器不会干坏事。**使用这两个选项时请务必小心!!**,虽然这些选项本身不太会破坏你的系统,你也不能盲目的接受他人的脚本程序。
### 总结
###总结
这篇文章当然只能触及包管理器的皮毛。还有很多别的包管理器笔者没有在这片文章里谈及。有些Linux发布版如Ubuntu或Elementary OS,已经在图形版的包管理器的开发上有了长远的进展。
这篇文章当然只能触及包管理器的皮毛。还有很多别的包管理器笔者没有在这篇文章里谈及。有些 Linux 发布版,如 Ubuntu 或 Elementary OS已经在图形版的包管理器的开发上有了长远的进展。
如果你对包管理器的更高级功能有进一步的兴趣,请在评论区留言,笔者很乐意进一步的写一写相关的文章。
###附录
### 附录
```
# search for packages
yum search <package>
@ -606,7 +602,7 @@ via: https://opensource.com/article/18/7/evolution-package-managers
作者:[Steve Ovens][a]
选题:[lujun9972](https://github.com/lujun9972)
译者:[DavidChenLiang](https://github.com/davidchenliang)
校对:[校对者ID](https://github.com/校对者ID)
校对:[wxy](https://github.com/wxy)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出