rpm命令详解及和yum之间的关系

    RPM 全名是“ RedHat Package Manager ”简称则为 RPM 顾名思义,当初这个软件管理的机制是由 Red Hat 这家公司发展出来的。 RPM 是以一种数据库记录的方式来将你所需要的软件安装到你的 Linux 系统的一套管理机制。

    但是安装的时候必须具备的相依赖性(依赖关系)软件,当安装在你的 Linux 主机时, RPM 会先依照软件里头的数据查询Linux 主机的相依赖性软件是否满足, 若满足则予以安装,若不满足则不予安装。为了解决这种具有依赖关系软件之间的问题 ,RPM 就在提供打包的软件时,同时加入一些讯息登录的功能,这些讯息包括软件的版本、 打包软件者、相依赖关系的其他软件、本软件的功能说明、本软件的所有文件记录等等,然后在 Linux 系统上面亦创建一个 RPM 软件数据库,如此一来,当你要安装某个以 RPM 型态提供的软件时,在安装的过程中, RPM 会去检验一下数据库里面是否已经存在相关的软件了, 如果数据库显示不存在,那么这个 RPM 文件“默认”就不能安装。这个就是 RPM 类型的文件最为人所诟病的“软件的依赖关系”问题。然而这种解决方法对用户来说,并没有什么卵用。所以就有了YUM的前端处理机制,将这些相依赖的软件先列表, 在有要安装软件需求的时候,先到这个列表去找,同时与系统内已安装的软件相比较,没安装到的依赖软件就一口气同时安装起来,就解决了相依属性的问题。


    

    rpm命令:rpm 选项 压缩包

            安装:-i,–install

            升级:-U,–update,-F,–freshen

            卸载:-e,–erase

            查询: -q,–query

            校验; -V,–verify

            数据库维护:–builddb,–initdab

    安装:

            rpm {-i|–install} [install-options] PACKAGE_FILE …

            rpm -ivh package-file(一般情况下都用此格式安装)

            通用选项

            -v:详细信息

            -vv:更详细的输出

            [install-options]

            -h:hash marks输出进度条;每个#号表示2%的进度 

            –test:测试安装,检测并报告依赖关系及冲突消息等

            –nodeps:忽略依赖关系(不保证可用性),不建议这么做

            –replacepkgs:重新安装

            –justdb:

            注意:rpm包可以自带脚本;

                四类:–noscripts

                –nopre preinstall:安装过程开始之前预习的脚本

                –nopost postinstall:安装过程完成那个之后运行的脚本

                –nopreun prenuninstall:卸载过程真正开始执行之前运行的脚本

                –nopostun postuninstall:卸载过程完成之后运行的脚本

                –nosignature:不检查包签名信息,及不检查来源合法性警告信息

                –nodigest:不检测包完整性信息

    升级:

            rpm -U –upgrade [install-options] package_file

            rpm -F –freshen[install-options]package_file

                -u:升级或者安装

                -F:升级

                rpm -Uvh package_file

                rpm -Fvh package_file

                –oldpackage:降级;

                –force:强制升级

注意: (1)不要对内核做升级操作;linux支持多内核版本并存,因此,直接安装新版本内核;

    (2)如果某原程序包的配置文件安装后曾被修改过,升级时,新版本的程序提供的同一个配置文件不会覆盖原版本的配置文件,而是把

       新版本的配置文件重命名(filename.rpmnew)后保留

    卸载:

            rpm -e package_name 

                –allmatches:卸载所有匹配指定名称的程序包的各版本

                –nodeps:忽略依赖关系

                –test:测试卸载,不真正执行

    查询:

            rpm -q{–query}[select-options][query-options]

                有两类选项

                [select-options]

                package_name:查询指定的程序包是否已经安装,及其版本

                -a,–all:查询所有已经安装过的所有包

                -f file:查询指定的文件由哪个程序包安装生成

            rpm -qf /etc/fstab;非常有用,可以查出文件是由哪个程序生成的

                    -p,–package PACKAGE_FILE:用于实现对未安装过的程序包执行查询操作;

                –whatprivides CAPABILITY:查询指定的CAPABILITY由哪个程序包提供;

                –whatrequires CAPABILITY:查询指定的CAPABILITY被哪个包所依赖

            [query-options]

                –changelog:查询rpm包的changlog;

                -l:列出程序安装生成的所有文件列表

                -i,–info:查询程序包相关的信息,版本号,大小,所属的包组,等;

                rpm -qi 此命令用到很多

                -c,–configfiles;查询指定的程序提供的配置文件

                -d,–docfiles:查询指定的程序包提供的文档;

                –provides:列出指定的程序包提供的所有capabity(功能)

                -R,–requires:查询指定的程序包的依赖关系

                –scripts:查看程序包自带的脚本片段

            用法:

                -qi PACKAGE,-qf file ,-ql package,-qd package

                -qpi package_file,-qpl package_file,-qpc package_file

    校验:

            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(MD5码发生变化)

            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(功能发生变化)

            包来源合法性和完整性验证;

            来源合法性验证:

                数字签名:

                完整性验证:

              获取并导入信任的包制作者的密钥

              对应centos发行版来说;rpm –import /etc/pki/rpm-/RPM-GRG-KEY-CENTOS-7gpgkey_file

             (一般为/media/cdrom/RPM-GRG-KEY-CENTOS-7和/etc/pki/rpm-gpg)七系统

      验证:

             1安装此组织前签名的程序时,会自动执行验证;

             2手动验证:rpm -K PACKAGE_FILE

     数据库重建:

             rpm管理器数据库路径/var/lib/rpm

             查询操作:通过此处的数据库进行;

     获取帮助:

              centos 6:man rpm

              centos 7:man rpmdb

              rpm{–initdb|–rebuilddb}

              –initdb:初始化数据库,当前无任何数据库可初始化创建一个新的;当前有时不执行任何操作;

              –rebuilddb:重新构建,通过读取当前系统上所有已经安装过的程序包进行重新创建;


原创文章,作者:M20-1马星,如若转载,请注明出处:http://www.178linux.com/37726

(0)
M20-1马星M20-1马星
上一篇 2016-08-21 20:47
下一篇 2016-08-21 20:47

相关推荐

  • 用户和组及批量创建

    用户和组       操作系统都有用户和组,windows,linux等等,用户和组用来做什么呢?       用户,是我们进入系统时的凭证,不是每一个人想进就进的。你想吧,如果操作系统没有用户就能登录进系统,那这就带来了许许多多的安全隐患了。而组则是为了方便管理用户的一个组容器。 &nb…

    系统运维 2016-08-04
  • Linux入门(二)

    linux基础命令及应用     shutdown:关机命令         -r:重启         -h:关机    &nb…

    Linux干货 2016-08-02
  • LVS实现负载均衡wordpress

    项目构建: LVS实现基于https wordpress 组建 必需软件: nfs-utils-1.2.3-70.el6.x86_64 配置步骤: 1.在D主机设置NFS共享目录 /app/nfsdata #mkdir /app/nfsdata //最好用LVM 实现在线扩展 #chown mysql: /app/data //确认该主机mysql用户存在 …

    2017-05-12
  • HAproxy实战

    HAproxy实验一 1、实验要求: (1) 动静分离discuzx,动静都要基于负载均衡实现; (2) 进一步测试在haproxy和后端主机之间添加varnish缓存(见实验二步骤); (3) 给出拓扑设计; (4) haproxy的设定要求: (a) 启动stats; (b) 自定义403、502和503的错误页; (c) 各组后端主机选择合适的调度方法…

    Linux干货 2016-11-15
  • LAMP平台基于NFS实现web服务器负载均衡

    前言 随着访问量的逐渐增大,一台web服务器可能已经无法满足需求,这就需要增加web服务器的数量了,于是问题就来了:如何保证两台服务器数据同步呢?本文将讲解如何基于NFS实现web服务器的负载均衡及数据同步。 NFS服务介绍 NFS(Network File System)网络文件系统,允许一个系统通过网络共享目录和文件,通过使用NFS,用户和程序可以像访问…

    Linux干货 2015-04-22
  • 实现NFS为lamp环境web站点提供共享存储

    1.实验需求 (1)nfs server导出/data/application/web,在目录中提供wordpress; (2)nfs client挂载nfs server导出的文件系统,至/var/www/html; (3)客户端1(lamp)部署wordpress,并让其正常访问,要确保正常发文章,上传图片。 (4)客户端2(lamp),挂载nfs se…

    Linux干货 2017-05-02

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-22 09:52

    软件包管理工具中rpm工具中的查询选项是比较常用的,而yum仓库的配置是一个基本技能,文章确实一笔带过,未深入介绍。