rpm 程序包管理器详解

简介

rpm(Redhat Package Manager),原是Redhat公司开发的一个包管理器,功能就是将编译好的应用程序的各组成文件打包成一个或几个程序包文件,从而更方便地实现程序包的安装、升级、卸载和查询等管理操作。

后来由于OpenLinux、S.u.S.E.以及Turbo Linux等Linux的分发版本都有采用,可以算是公认的行业标准了,现已将rpm缩写展开为RPM Package Manager

程序包组成

每个程序包都由自身的文件清单和脚本,以及系统上的公共存储数据库组成。

程序包的组成清单(每个程序包都单独实现):

  1. 文件清单;
  2. 安装或卸载时运行的脚本。

数据库(公共)主要存储了以下内容:

  1. 程序包的名称和版本;
  2. 依赖关系;
  3. 功能说明;
  4. 安装生成的各文件的文件路径及校验码信息;
  5. 等等等。

数据库存储路径为:/var/lib/rpm/

rpm命令简介

rpm命令主要是对程序包进行安装、升级、卸载、查询和校验、数据库维护等操作,其主要操作为:

1
2
3
4
5
6
7
8
rpm命令:rpm [OPTIONS] [PACKAGE_FILE]

安装:-i, --install
升级:-U, --update, -F, --freshen
卸载:-e, --erase
查询:-q, --query
校验:-V, --verify
数据库维护:--builddb, --initdb

程序包安装

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
rpm {-i|--install} [install-options] PACKAGE_FILE ...

# 常用操作:
rpm -ivh PACKAGE_FILE

# 常用选项:
-v:verbose,详细信息;
-vv:更详细的输出;

# 附加安装选项:
-h:hash marks输出进度条;每个 # 表示2%的进度;
--test:测试安装,检查并报告依赖关系及冲突消息等;
--nodeps:忽略依赖关系;不建议;
--replacepkgs:重新安装;

# 高级安装选项:
--noscripts
preinstall:安装过程开始之前运行的脚本,%pre , --nopre;
postinstall:安装过程完成之后运行的脚本,%post , --nopost;
preuninstall:卸载过程真正开始执行之前运行的脚本,%preun, --nopreun ;
postuninstall:卸载过程完成之后运行的脚本,%postun , --nopostun;
--nosignature:不检查包签名信息,不检查来源合法性;
--nodigest:不检查包完整性信息;

程序包升级

1
2
3
4
5
6
7
8
9
10
11
12
13
# 升级或安装
rpm {-U|--upgrade} [install-options] PACKAGE_FILE ...

# 只升级存在的包
rpm {-F|--freshen} [install-options] PACKAGE_FILE ...

# 常用操作:
rpm -Uvh PACKAGE_FILE ...
rpm -Fvh PACKAGE_FILE ...

# 常用选项:
--oldpackage:降级;
--force:强制升级;

注意:
(1) 不要对内核做升级操作;Linux支持多内核版本并存,因此,直接安装新版本内核。
(2) 如果某原程序包的配置文件安装后曾被修改过,升级时,新版本的程序提供的同一个配置文件不会覆盖原有版本的配置文件,而是把新版本的配置文件重命名(FILENAME.rpmnew)后提供。

程序包卸载

1
2
3
4
5
6
7
8
9
rpm {-e|--erase} [--allmatches] [--nodeps] [--noscripts] [--notriggers] [--test] PACKAGE_NAME ...

# 常用操作
rpm -evh PACKAGE_FILE ...

# 常用选项
--allmatches:卸载所有匹配指定名称的程序包的各版本;
--nodeps:忽略依赖关系;
--test:测试卸载,dry run模式;

程序包查询

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
rpm {-q|--query} [select-options] [query-options]

# 常用操作
rpm -q PACKAGE_NAME

# 常用选项
PACKAGE_NAME:查询指定的程序包是否已经安装,及其版本;
-a, --all:查询所有已经安装过的包;
-f FILE:查询指定的文件由哪个程序包安装生成;
-p, --package PACKAGE_FILE:用于实现对未安装的程序包执行查询操作;
--whatprovides CAPABILITY:查询指定的CAPABILITY由哪个程序包提供;
--whatrequires CAPABILITY:查询指定的CAPABILITY被哪个包所依赖;

# 附加选项
--changelog:查询rpm包的changlog;
-l, --list:程序安装生成的所有文件列表;
-i, --info:程序包相关的信息,版本号、大小、所属的包组,等;
-c, --configfiles:查询指定的程序包提供的配置文件;
-d, --docfiles:查询指定的程序包提供的文档;
--provides:列出指定的程序包提供的所有的CAPABILITY;
-R, --requires:查询指定的程序包的依赖关系;
--scripts:查看程序包自带的脚本片断;

程序包校验

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
rpm {-V|--verify} [select-options] [verify-options]

# 常用操作
rpm -V PACKAGE_NAME

# 执行后无输出则为校验通过

# 若有输出,则说明校验不通过,可根据位置符号进行判断
S file Size differs
M Mode differs (includes permissions and file type)
5 digest (formerly MD5 sum) differs
D Device major/minor number mismatch
L readLink(2) path mismatch
U User ownership differs
G Group ownership differs
T mTime differs
P caPabilities differ
```

## 导入密钥

```shell
# CentOS 7 官方的密钥一般存在于 /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7

数据库重建

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
rpm {--initdb|--rebuilddb} [--dbpath DIRECTORY] [--root DIRECTORY]

# 常用选项
--initdb:初始化数据库,当前无任何数据库可实始化创建一个新的;当前有时不执行任何操作;
--rebuilddb:重新构建,通过读取当前系统上所有已经安装过的程序包进行重新创建;
```

## 获取帮助

```shell
# CentOS 6
man rpm

# CentOS 7
man rpmdb

聚合图

程序包管理工具

图片摘自:http://www.178linux.com/39163