系统版本:
[root@centos71d1 ~]# cat /etc/redhat-release
CentOS Linux release 7.1.1503 (Core)
[root@centos71d1 ~]# uname -r
3.10.0-229.el7.x86_64
rpm命令用于在Linux系统中查询、安装、升级、卸载、校验程序包,以及维护rpm数据库。
基本命令
语法:
rpm OPTIONS PACKAGE_FILE
OPTIONS:
- 查询:
-q
, --query - 安装:
-i
, --install - 升级:
-U
, --update,-F
, --freshen - 卸载:
-e
, --erase - 校验:
-V
, --verify - 数据库维护: --builddb, --initdb
查询
语法:
rpm { -q | --query } [select-options] [query-options]
[select-options]
- PACKAGE_NAME: 查询指定的程序包是否已经安装,及其版本
- -a, --all: 查询所有已经安装过的包
- -f FILE: 查询指定的文件由哪个程序包安装生成
- -p, --package PACKAGE_FILE: 用于实现对未安装的程序包执行查询操作
- --whatprovides CAPABILITY(能力): 查询指定的CAPABILITY由哪个程序包提供
- --whatrequires CAPABILITY: 查询指定的CAPABILITY被哪个包所依赖
[query-options]
- --changelog: 查询rpm包的changlog
- -l, --list: 程序包安装生成的所有文件列表
- -i, --info: 程序包相关的信息,例如版本号、大小、所属的包组等
- -c, --configfiles: 查询指定的程序包提供的配置文件
- -d, --docfiles: 查询指定的程序包提供的文档
- --provides: 列出指定的程序包提供的所有的CAPABILITY
- -R, --requires: 查询指定的程序包的依赖关系
- --scripts: 查看程序包自带的脚本片断
示例:
[root@centos71d1 ~]# rpm -ivh zsh-5.0.2-28.el7.x86_64.rpm
[root@centos71d1 ~]# rpm -q zsh
zsh-5.0.2-28.el7.x86_64
#查询是否已经安装了zsh这个程序包,如果已经安装,则显示程序名和版本
[root@centos71d1 ~]# rpm -qa
#查询系统中已安装的所有的程序包
[root@centos71d1 ~]# rpm -qa | grep "^z"
zlib-1.2.7-13.el7.x86_64
zip-3.0-11.el7.x86_64
zsh-5.0.2-28.el7.x86_64
#查询系统中已安装的以“z”开头的程序包
[root@centos71d1 ~]# rpm -qf /etc/fstab
setup-2.8.71-5.el7.noarch
#查询文件的来源
[root@centos71d1 ~]# rpm -q --changelog bash | less
#查询bash的程序包(rpm包)的changelog
[root@centos71d1 ~]# rpm -ql bash
#查询bash程序包安装生成的文件列表
[root@centos71d1 ~]# rpm -qi bash
#查询bash这个程序包的详细信息
[root@centos71d1 ~]# rpm -qc bash
/etc/skel/.bash_logout
/etc/skel/.bash_profile
/etc/skel/.bashrc
#查询bash程序包提供了哪些配置文件
[root@centos71d1 ~]# rpm -qd bash
#查询bash程序包提供了哪些文档
[root@centos71d1 ~]# rpm -q --provides bash
/bin/bash
/bin/sh
bash = 4.2.46-12.el7
bash(x86-64) = 4.2.46-12.el7
config(bash) = 4.2.46-12.el7
#查询bash程序包提供了哪些capability
[root@centos71d1 ~]# rpm -q --whatprovides bash
bash-4.2.46-12.el7.x86_64
#查询哪个程序包提供了“bash”这个capability
[root@centos71d1 ~]# rpm -q --whatrequires bash
initscripts-9.49.24-1.el7.x86_64
dracut-033-240.el7.x86_64
rsyslog-7.4.7-7.el7_0.x86_64
lvm2-2.02.115-3.el7.x86_64
bash-completion-2.1-6.el7.noarch
bash-completion-extras-2.1-11.el7.noarch
#查询哪些程序包需要依赖bash程序包
[root@centos71d1 ~]# rpm -qR bash
#查询bash程序包需要依赖哪些capability
[root@centos71d1 ~]# rpm -q --scripts bash
#查询bash程序包携带的安装脚本
[root@centos71d1 ~]# rpm -qpi zsh-5.0.2-28.el7.x86_64.rpm
#查询还未安装的zsh程序包的详细信息
[root@centos71d1 ~]# rpm -qpl zsh-5.0.2-28.el7.x86_64.rpm
#查询还未安装的zsh程序包,安装后将生成哪些文件
安装
语法:
rpm { -i | --install } [install-options] PACKAGE_FILE …
[general-options]
- -v: verbose,详细信息
- -vv: 更详细的信息
[install-options]
- -h: hash marks,输出进度条,每个#表示2%的进度
- --test: 测试安装,检查并报告依赖关系及冲突信息等
- --nodeps: 忽略依赖关系(不建议)
- --replacepkgs: 重新安装
- --nosignature: 不检查包签名信息,不检查包来源合法性
- --nodigest: 不检查包完整性信息
示例:
[root@centos71d1 ~]# mount -r /dev/cdrom /media/
#挂载centos7.1安装光盘
[root@centos71d1 ~]# cd /media/Packages/
[root@centos71d1 Packages]# rpm -ivh zsh-5.0.2-7.el7.x86_64.rpm
#安装zsh,显示安装信息,hash marks输出进度条
[root@centos71d1 Packages]# rpm -ivvh zsh-5.0.2-7.el7.x86_64.rpm
#安装zsh,hash marks输出进度条,显示更详细的安装信息
[root@centos71d1 Packages]# rpm -q zsh
zsh-5.0.2-7.el7.x86_64
#查询已安装的zsh包
[root@centos71d1 Packages]# rpm -ql zsh | less
#查询安装zsh生成的所有文件的列表
[root@centos71d1 Packages]# rpm -e zsh
#卸载zsh
[root@centos71d1 Packages]# rpm -ivh --test php-common-5.4.16-23.el7_0.3.x86_64.rpm
error: Failed dependencies:
libzip.so.2()(64bit) is needed by php-common-5.4.16-23.el7_0.3.x86_64
#安装测试,测试安装冲突或依赖关系
[root@centos71d1 Packages]# rpm -ivh --nodeps php-common-5.4.16-23.el7_0.3.x86_64.rpm
#忽略依赖关系安装,安装完成后,不一定可以使用
#假如修改了某工具的配置文件,无法复原,可以这样做:
#1. 删除该配置文件
#2. 覆盖安装
[root@centos71d1 Packages]# rm -f /etc/zshrc
[root@centos71d1 Packages]# rpm -ivh --replacepkgs zsh-5.0.2-7.el7.x86_64.rpm
升级
语法:
rpm { -U | --upgrade } [install-options] PACKAGE_FILE …
rpm { -F | --freshen } [install-options] PACKAGE_FILE …
OPTIONS:
- -U: 升级或安装
- -F: 升级
- --oldpackage: 降级
- --force: 强制升级
注意:
- 不要对内核做升级操作,Linux支持多内核版本并存,可直接安装新版本内核
- 如果某原程序包的配置文件安装后曾被修改过,升级时,新版本的程序提供的同一个配置文件不会覆盖原有版本的配置文件,而是把新版本的配置文件重命名(FILENAME.rpmnew)后提供
示例:
[root@centos71d1 ~]# rpm -q zsh
zsh-5.0.2-7.el7.x86_64
[root@centos71d1 ~]# wget http://mirror.centos.org/centos/7/os/x86_64/Packages/\
zsh-5.0.2-28.el7.x86_64.rpm
[root@centos71d1 ~]# rpm -Uvh zsh-5.0.2-28.el7.x86_64.rpm
卸载
语法:
rpm { -e | --erase } [--allmatches] [--nodeps] [--noscripts] [--test] PACKAGE_NAME …
OPTIONS:
- --allmatches: 卸载所有匹配指定名称的程序包的所有版本
- --nodeps: 忽略依赖关系
- --test: 测试卸载,dry run模式
示例:
[root@centos71d1 ~]# rpm -e zsh
#卸载zsh;卸载只需要指定包名,而安装,需要指定包文件
校验
语法:
rpm { -V | --verify } [select-options] [verify-options]
代码:
- 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
示例:
[root@centos71d1 ~]# rpm -ql zsh
/usr/share/zsh/5.0.2/functions/zfput
....
[root@centos71d1 ~]# file /usr/share/zsh/5.0.2/functions/zfput
/usr/share/zsh/5.0.2/functions/zfput: ASCII text
[root@centos71d1 ~]# vim /usr/share/zsh/5.0.2/functions/zfput
#往zfput文件添加任意内容
[root@centos71d1 ~]# rpm -V zsh
S.5....T. /usr/share/zsh/5.0.2/functions/zfput
#对zsh程序包生成的所有文件执行校验,发现zfput文件发生改变;S表示大小,5表示md5,T表示修改时间
来源合法性和完整性验证
- 制作者使用自己的私钥加密程序包的特征码,得到签名
- 使用者使用制作者的公钥,解密签名,可以得到程序包的特征码
- 使用者计算程序包的特征码,与解密后得到的特征码对比,如匹配,则可以确认该程序包完整,同时确认程序包来源于制作者,即程序包来源合法
获取并导入信任的包制作者密钥:
对于CentOS发行版:rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
验证:
- 安装此组织签名的程序时,会自动执行验证
- 手动验证:
rpm -K PACKAGE_FILE
示例:
[root@centos71d1 ~]# rpm -e zsh
[root@centos71d1 ~]# rpm --import /media/RPM-GPG-KEY-CentOS-7
or [root@centos71d1 ~]# rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
#导入centos7安装光盘上的程序包(rpm包)制作者的公钥,\
#可以验证安装光盘中提供的程序包的来源合法性和完整性;\
#通常该公钥也随系统的安装保存在/etc/pki/rpm-gpg目录中
[root@centos71d1 ~]# rpm -ivh zsh-5.0.2-28.el7.x86_64.rpm
Preparing... ################################# [100%]
Updating / installing...
1:zsh-5.0.2-28.el7 ################################# [100%]
#导入公钥之后,在安装程序包时,就不会有警告提示
[root@centos71d1 ~]# rpm -K zsh-5.0.2-28.el7.x86_64.rpm
zsh-5.0.2-28.el7.x86_64.rpm: rsa sha1 (md5) pgp md5 OK
#也可手动验证程序包文件的来源合法性和完整性
数据库维护
rpm管理器数据库路径: /var/lib/rpm
语法:
rpm { --initdb | --rebuilddb } [--dbpath DIRECTORY] [--root DIRECTORY]
获取帮助:
- CentOS 6: man rpm
- CentOS 7: man rpmdb
选项:
- --initdb: 初始化数据库,当前无任何数据库可初始化创建一个新的;反之不执行任何操作
- --rebuilddb: 通过读取当前系统上所有已经安装的程序包,重新构建数据库