Linux:RPM

RPM的全名是 Red Hat Package Manager,本意是Red Hat 软件包管理,顾名思义是Red Hat 贡献出来的软件包管理;在Fedora 、Redhat、Mandriva、SuSE、YellowDog等主流发行版本,以及在这些版本基础上二次开发出来的发行版采用。

简单来说,RPM是以一种数据库记录的方式将所需要的软件安装到Linux主机的一套管理程序,最大的特点是将要安装的软件先编译并打包,通过包装好的软件中默认的数据库记录,记录这个软件在安装的时候需要的依赖属性模块,在用户的Linux主机安装时,RPM会先根据软件里的记录数据,查询Linux主机的依赖属性软件是否满足,若满足则予以安装,不满足则不安装。安装的时候将该软件的信息全部写入RPM的数据库中以便将来的查询、验证与卸载。

软件安装流程如下:

总结一下,RPM的 用途有以下几点:

1、安装、删除、升级和管理软件;当然也支持在线安装和升级软件;

2、通过RPM包管理能知道软件包包含哪些文件,也能知道系统中的某个文件属于哪个软件包;

3、可以在查询系统中的软件包是否安装以及其版本;

4、作为开发者可以把自己的程序打包为RPM 包发布;

5、软件包签名GPG和MD5的导入、验证和签名发布

6、依赖性的检查,查看是否有软件包由于不兼容而扰乱了系统;

1. 优点

  • 由于已经编译完成并且打包,所以安装很方便
  • 由于套件信息已经记录在Linux主机的数据库中,方便查询、升级与卸载

2. 缺点

  • 安装环境必须与打包时的环境一致
  • 需要满足软件的依赖属性需求
  • 卸载时需要非常小心。最底层的软件不能先删除,否则可能会导致整个系统出现问题。
    [En]

    you need to be very careful when uninstalling. The lowest-level software cannot be deleted first, otherwise it may cause problems with the whole system.*

RPM软件的安装、删除、更新只有root权限才能使用;对于查询功能任何用户都可以操作;如果普通用户拥有安装目录的权限,也可以进行安装。

1. 命名格式

  • name-version-arch.rpm
  • name-version-arch.src.rpm

2. 说明

  • name:软件包名称。
  • version:带有主、次和修订的软件包版本。
  • arch:硬件平台。硬件平台包括了:i386、i486、i586、i686、x86_64、ppc、sparc、alpha
  • src.rpm:源代码包。

3. 范例

以”openssl-1.0.1c-1.fc18.i686.rpm”为例:

  • openssl:是软件名称。
  • 1.0.1c-1:是软件版本。
  • i686:是适用的硬件平台。

4. 特殊名称

1)fcXX,elXX:表示这个软件包的发行商版本,就像这里的fc18,说明这个软件包是在Fedora 18下使用的。而openssl-1.0.0-20.el6.x86_64.rpm表示这个软件包是在RHEL 6.x(Red Hat Enterprise Linux)/CentOS 6.x下使用。

2)devel:表示这个RPM包是软件的开发包,例如mysql-devel-5.1.52-1.el6_0.1.i686.rpm。

3)noarch:说明这样的软件包可以在任何平台上安装,不需要特定的硬件平台。在任何硬件平台上都可以运行。

一)RPM的软件包查询功能

RPM在查询的时候,查询的地方是在/var/lib/rpm目录下的数据库文件。

命令格式:

从上面的命令看来,根据后面所带的参数来区分可以分为四种:

  1. 后面不接名称的

  2. -qa:查询所有已经安装的软件名称

  3. 后面接已经安装的软件名称的:

  4. -q:查询后面接的软件是否安装,已安装有信息输出,否则没有

  5. -qi:列出该软件的详细信息(information),包含开发商、版本与说明等
  6. -ql:列出该软件所有的文件与目录(list)
  7. -qc:列出该软件的所有配置文件
  8. -qd:列出该软件的所有帮助文件(与man有关的文件)
    • qR:列出与该软件有关的依赖软件所含的文件(Required)
  9. 后面接一个存在于系统的文件名称

  10. -qf:找出该文件属于哪个已安装的软件

  11. 后面接一个.rpm文件

  12. -qp[licdR]:-qp后面接的所有参数以上面的说明为准,目的在于找出某个rpm文件内的信息,而非已安装的软件信息

二)软件包的安装和升级

  1. 安装

1)命令格式

2)范例

如果您在安装过程中发现问题,或者您已经知道会发生什么并坚持安装,您可以使用“force”安装参数:

[En]

If you find a problem during the installation process, or if you already know what will happen and insist on installing it, you can use the “ force ” installation parameter:

可执行的参数

表示意义

–nodeps

使用时机:如果安装某个套件事,总足发现rpm告诉您”有相关厲性的套件尚未安装”,而您又想直接强制安装这个套件,可以加上–nodeps告知RPM不要去检查套件的依赖性。

危险性:套件有依赖性的原因是因为彼此会使用对方的机制或功能,如强制安装而不考虑套件的属性依赖,则可能会进成该套件无法正常使用

–nomd5

使用时机:不想检查RPM文件所含的MD5信息时

说明:除非您很清楚这个套件的来源,否则建议不使用这个参数

–noscripts

使用时机:不想让该套件自行启用或者自行执行某些系统命令

–replacefiles

危险性:覆盖的操作是无法复原的。所以,必须要很清楚地知道被覆盖的文件真的不重要

–replacepkgs

使用时机:重新安装某个已经安装过的套件

–force

使用时机:这个参数其实就是—replacefiles与—replacepkgs的综合体

–test

使用时机:想要测试一下该套件是否可以安装到用户的Linux环境中,范例:

Rpm –ivh pkgname.i386.rpm –test

2.升级

1)命令格式

三)RPM卸载与重建数据库

  1. 命令格式

注意,卸载过程要自上而下,否则会出现结构问题。由于一直在修改文件内容,有时候会导致数据库有点乱,这个时候就可以使用命令重建rpm的数据库。

四)RPM验证与数字签名

验证功能主要是向系统管理员提供一种有用的管理机制,方式是用数据库内容,来比较当前Linux系统环境的所有软件文件,当有数据丢失或者误删/修改某个软件的文件时,就用这种方法来验证原理的文件系统,以了解改动的地方。

  1. 命令格式

  2. 从范例看 修改因素

查询/etc/crontab是否被更改过

rpm –Vf /etc/crontab

S.5…..T c /etc/crontab

上面的信息从左到右分别表示已改变的因素:

  • S:(file Size differs)文件的容量大小
  • M:(Mode differs)文件的类型或属性,以及可执行参数
  • 5:(MD5 sum differs)MD5这一加密防被黑的属性
  • D:(Device major/minor number mis-match)设备名称
  • L:(readLink(2)path mis-match)Link属性
  • U:(User ownership differs)文件的拥有者
  • G:(Group ownership differs)文件所属用户组
  • T:(mTime differs)文件的建立时间

如果一个文件全部信息都改过,显示会是:

SM5DLUGT c filename

其中c表示”Config file”,也就是文件类型,文件类型有几类:

  • c:配置文件,config file
  • d:文档文件,documentation
  • g:ghost文件,通常该文件不包含在某个软件中,较少发生,ghost file
  • l:授权文件,license file
  • r:自述文件,read me

经过验证就知道哪个文件被改过,是否符合预期。

  1. 数字签名

rpm可以使用数字签名来判断待安装的软件是否有问题,对数字签名不熟悉的,可以看看阮一峰的两篇文章:

一般我们使用的是GPG的公钥,方法很简单,如果想要使用某个软件,就要将该发布商的GPG公钥先安装到自己的系统上,然后,安装软件时,就会坚持两个密钥是否相同,如果相同就直接安装,不同则在显示信息,之初未安装发布商的GPG公钥。

安装公钥方法很简单,如red hat系统自带有公钥,安装方法:

一般来说,Linux系统都会发布自己的GPG密钥,可以使用以下命令来搜索文件:

已经安装的公钥可以用下面命令查询

然后选取gpg-pubkey-…文件来查看信息

本文开头介绍了RPM的由来和用途,然后分析了RPM的优缺点和使用权限,最后重点将了包的命名规则和RPM的基本用法。

虽然RPM很好用,但是实际上现在已经出现了基于RPM包管理的,更强大的工具,如yum。所以建议在安装软件的时候,还是使用yum来安装。

Original: https://www.cnblogs.com/volcao/p/13823177.html
Author: 何永灿
Title: Linux:RPM

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/10134/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

免费咨询
免费咨询
扫码关注
扫码关注
联系站长

站长Johngo!

大数据和算法重度研究者!

持续产出大数据、算法、LeetCode干货,以及业界好资源!

2022012703491714

微信来撩,免费咨询:xiaozhu_tec

分享本页
返回顶部