CentOS软件包管理之RPM

很多人最识Linux的时候,搞不明白什么是软件包管理系统,其实,linux下的软件包管理系统就是在电脑中自动安装、配置、卸载和升级软件包的工具组合,有点类似于windows下的控制面板。

Linux发行版中,几乎每一个发行版都有自己的软件包管理系统。常见的有deb软件包的dpkg以及它的前端apt(适用于debian、Ubuntu等)。rpm以及它的前端yum(适用于RedHat系列的系统)。

RPM,全称RPM Package Manager,是由Red Hat推出的软件包管理系统,现在在各种发行版中普遍适用。

RRM软件包是将程序源代码经过编译和封装以后形成的包文件,在软件包里面会封装软件的二进制程序、配置文件、帮助手册、库文件以及头文件等。RPM包的结构如下图所示:

CentOS软件包管理之RPM

RPM软件包的安装与卸载:
# rpm [options] /path/to/rpmfile

option:
-i|--install:安装指定软件
-v|--verbose:显示安装过程
-e|--erase:卸载指定的软件
-h|--hash:以#的方式显示安装进度条,一个#为2%
--nodeps:忽略依赖关系
--test:测试安装
-U:升级+安装(如果之前有安装则升级,如果之前没有安装则安装)
-F:升级(如果之前有安装则升级,如果之前没安装则不做任何操作)
--replacepkgs:重新安装软件包
--force:在软件包的安装或升级过程中,如果出现某个文件已经安装或者某一个软件已经安装时
可以使用--force选项强制安装,等同于--replacepkgs --replacefiles --oldpackage同时使用


常用的软件包安装选项为:
#rpm -ivh /path/to/rpmfile
# rpm -Uvh /path/to/rpmfile


示例 1:

CentOS软件包管理之RPM

RPM软件包验证:
RPM包使用gpg非对称加密机制,可以验证包的完整性和来源的合法性。
# rpm --import PUBKEY:rpm使用--import导入软件包提供者制作的公钥,可以自动进行软件包的验证
#rpm {-K|--checksig}  [--nosignature] [--nodigest] PACKAGE_FILE:rpm可以使用-K或--checksig选项对软件包进行来源和完整性的验证,--nosignature选项是指不进行来源合法性验证,--nodigest选项是指不进行完整性验证


示例 2:

CentOS软件包管理之RPM

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/18509.html