LINUX下的RPM应用

一 前言

在进入RPM的应用前,关于可执行程序的一些基本知识有必要说明一下:

1 ABI:application binary interface,这是应用程序与系统间的协议,大家都知道同一个程序在不同的操作系统平台可能会无法执行,很大程度上就是因为ABI的不同,因此,对于可执行程序,选择对应操作系统平台是第一步

2 API:application programming interface,这个概念很重要,如何理解呢?抛开那些复杂的概念的不说,程序的运行并不是孤立的,运行过程中需要调用能实现各种功能的库(函数)文件,否则无法保证程序的正常运行(有兴趣的朋友可以试试#rm -f  /lib64/libc.so.6),所以在程序安装前,得保证相应的库文件已准备完毕

3 软件结构:通常一个完善的二进制应用程序应该包括四个部分(二进制文件,库文件,配置文件,帮助文件 )


二  RPM应用场景

               在软件安装的工具选择中,RPM因为软件依赖性的存在使得很多软件的安装过于复杂,通常对于RPM包的安装选择YUM会比较简单粗暴(YUM会自动解决依赖性问题),在此不介绍RPM的安装。RPM工具的使用更多是在查询,校验,抽取文件等等方面

1. 查询: RPM的查询基于软件包的数据库/var/lib/rpm,这个数据库很重要,一旦遭到破坏会影响整个         RPM的管理;查询的相关命令如下:

    rpm    -q   pkgname(包名):查询RPM包是否被安装

              -qa  查询所有已安装的RPM包,结合grep可用来获取想要查询的信息;也可以使用rpm -qa                             “keyword”的形式查询某些关键字相关的结果

              -qf   /path/to/file    查询某文来源于哪个包

              -ql   pkgname       查询已安装包在系统中的文件列表

              -qpl  /path/to/file    查询未安装包的文件列表 

              -qc    pkgname      查询相关包配置文件

2. 校验:RPM提供校验功能,可查看文件是否被修改过,以保证系统安全(特别针对于被改过的可执行     文件);校验结果是比对当前包与RPM数据库(RPM数据库的重要性!)得出的结果 

         rpm     -V     pkgname    

    校验结果为SM5DLUGTP:被修改后显示对应字母(每个字母表示特定内容)被修改,无改动显示为点         号”.” 

3. 验证包来源合法性与完整性,验证前需要先导入公钥——安装系统时/etc/pki/rpm-gpg下会生成

    导入公钥:rpm    –import    /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6

                 rpm     -K    /path/to/file    

4. 包内文件查看并提取:rpm2cpio -tv /path/to/rpmpkgs | cpio -id ./path/to/file
    PS:-tv为查看rpm包内的文件,路径必须为完整路径 -id为提取某文件,提取的文件路径必须完整

原创文章,作者:sevenyellow,如若转载,请注明出处:http://www.178linux.com/73576

(2)
sevenyellowsevenyellow
上一篇 2017-04-17 22:51
下一篇 2017-04-18 08:46

相关推荐

  • 端口转发实例

    什么是端口转发?      端口转发(Port forwarding),有时被叫做隧道,是安全壳(SSH) 为网络安全通信使用的一种方法。端口转发是转发一个网络端口从一个网络节点到另一个网络节点的行为,其使一个外部用户从外部经过一个被激活的NAT路由器到达一个在私有内部IP地址(局域网内部)上的一个端口。 为什么需要端口转发? …

    2017-04-13
  • nfs的简单配置及引用

    nfs: Network File System RPC:Remote Procedure Call NFS: sun公司研发, 协议;     NFSv1,没有走出实验室     NFSv2(不安全), NF…

    Linux干货 2016-10-19
  • 马哥教育网络班20期+第3周课程练习

     1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 法一: who | cut -d ‘ ‘ -f 1 | tail -u 法二: who | cut -d ’’-f&…

    Linux干货 2016-06-26
  • iptables

      iptables(1) Firewall:隔离工具;Packets Filter Firewall;工作于主机或网络的边缘,对经由的报文根据预先定义的规则(匹配条件) 进行检测,对于能够被规则匹配到的报文实行某预定义的处理机制的一套组件;     硬件防火墙:在硬件级别实现部分功能的防…

    Linux干货 2016-11-01
  • 第八周

    1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别。 网桥(Bridge)是早期的两端口二层网络设备,用来连接不同网段。网桥的两个端口分别有一条独立的交换信道,不是共享一条背板总线,可隔离冲突域。网桥比集线器(Hub)性能更好,集线器上各端口都是共享同一条背板总线的。后来,网桥被具有更多端口、同时也可隔离冲突域的交换机(Switch…

    Linux干货 2016-09-19
  • 0806文本处理工具

    ———- 文件查看工具 ———- cat:    cat [OPTION]… [FILE]…   //查看文本文件内容,一般后面跟文件名(相对路径),或者是文件名(绝对路径) -n 加行号 -b 加行号,…

    Linux干货 2016-08-07

评论列表(1条)

  • renjin
    renjin 2017-04-21 09:46

    主要介绍了rpm命令常用的几个参数,内容总结的很好,建议插入一些示例和执行的结果,并将终端提示符类的命令或代码放入到”插入程序代码”中