linux运行.rpm,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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值