码迷,mamicode.com
首页 > 其他好文 > 详细

rpm

时间:2015-12-22 06:33:52      阅读:230      评论:0      收藏:0      [点我收藏+]

标签:配置文件   管理系统   源代码   数据库   二进制   包管理   

Rpm包的基本信息

在早期由于要安装一个程序,要解决程序之间的依赖关系,费好多的精力,如果运气不好的话,装一上午,都不一定能装上,可能会出现以下情况 :

技术分享

那就悲剧了,发行商们就想办法,这就是包管理器的由来。

 

RPM全称是 Red Hat Package ManagerRed Hat包管理器)。几乎所有的 Linux 发行版本都使用这种形式的软件包管理安装、更新和卸载软件。

 

RPM是一个开放的软件包管理系统。它工作于Red Hat Linux以及其它LinuxUNIX 系统,可被任何人使用。redhat软件公司鼓励其它厂商来了解RPM并在自己的产品中使用它。RPM的发布基于GPL协议。对于最终用户来说,使用RPM所提供的功能来维护系统是比较容易和轻松的。安装、卸载和升级RPM软件包只需一条命令就可以搞定。RPM维护了一个所有已安装的软件包和文件的数据库,可以让用户进行查询和验证工作。在软件包升级过程中,RPM会对配置文件进行特别处理,绝对不会丢失以往的定制信息。对于程序员RPM可以让我们连同软件的源代码打包成源代码和二进制软件包供最终用户使用。

 

RPM拥有功能强大的查询选项。我们可以搜索数据库来查询软件包或文件。也可以查出某个文件属于哪个软件包或出自哪儿。RPM软件包中的文件是以压缩格式存放的,拥有一个定制的二进制头文件,其中包含有关包和内容的信息,可以让我们对单个软件包的查询简便又快速。

 

RPM另一个强大的功能是进行软件包的验证。如果我们担心误删了某个软件包中的某个文件,我们就可以对它进行验证。任何非正常现象将会被通知。如果需要的话还可以重新安装该软件包。在重新安装过程中,所有被修改过的配置文件将被保留。

 

RPM设计目标之一就是要保持软件包的原始特征, 就象该软件的原始发布者发布软件时那样。通过使用RPM我们可以拥有最初的软件和最新的补丁程序,还有详细的软件构建信息。

RPM包有一个强大的数据库,里面有你的程序名称和版本号、程序的依赖关系功能的说明、安装生产的各文件的路径及校验码信息等等...。都在/var/lib/rpm里面。

 

CentOS 7系统上rpm命令管理程序包:

安装、升级、卸载、查询和校验、数据库维护

rpm命令:rpm  [OPTIONS]  [PACKAGE_FILE]

安装:-i, --install

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

卸载:-e, --erase

查询:-q, --query

校验:-V, --verify

数据库维护:--builddb, --initdb


 

安装:rpm -ivh 包全名

-i :安装

-v :详细信息

-vv:更详细的信息

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

技术分享

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

技术分享

--nodeps:忽略依赖关系;不建议使用,除了特殊情况,它所依赖的包不重要,可以忽略。

技术分享

--replacepkgs:重新安装

技术分享

注意:rpm可以自带脚本;把这几个脚本都写上,基本很少用


preinstall:安装过程开始之前运行的脚本,%pre , --nopre

技术分享

postinstall:安装过程完成之后运行的脚本,%post , --nopost

技术分享

preuninstall:卸载过程真正开始执行之前运行的脚本,%preun, --nopreun 

技术分享没有信息就是最好的信息,说明它没出错

postuninstall:卸载过程完成之后运行的脚本,%postun , --nopostun

技术分享

 

--nosignature:不检查包签名信息,不检查来源合法性

技术分享

不只大家注意没之前演示的上面都有警告信息,那就是验证信息的。下面会让他验证信息,请耐心往下看。

--nodigest:不检查包完整性信息;

技术分享

有些信息它是隐藏的不会显示出来,只要不报错就Ok

升级

-U:升级或安装;

-F:升级


rpm  -Uvh PACKAGE_FILE ...

技术分享

rpm  -Fvh PACKAGE_FILE ...

技术分享

--oldpackage:降级;

技术分享

--force:强制升级

技术分享


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

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

 

卸载

rpm -e 包名

技术分享:没有信息就是最好的信息

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

技术分享

--nodeps:忽略依赖关系

Rpm -e --nodeps httpd

--test:测试卸载,dry run模式

技术分享

查询

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

技术分享

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

]# rpm -qa

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

技术分享

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

技术分享

--whatprovides CAPABILITY:查询指定的CAPABILITY由哪个程序包提供

技术分享

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

技术分享

--changelog:查询rpm包的changlog

技术分享

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

技术分享

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

技术分享

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

技术分享

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

技术分享

   --provides:列出指定的程序包提供的所有的CAPABILITY

技术分享

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

技术分享

  --scripts:查看程序包自带的脚本片断;

技术分享校验

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

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-gpg/RPM-GPG-KEY-CentOS-7

    注意:导入进去将不会出现之前安装程序图片中出现的警告信息

技术分享


验正:

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

(2) 手动验正:rpm -K PACKAGE_FILE

技术分享


数据库重建

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

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


获取帮助:

CentOS 6man rpm

CentOS 7man rpmdb


rpm {--initdb|--rebuilddb} [--dbpath DIRECTORY] [--root DIRECTORY]

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

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

 

实例:使用--dbpath指定数据库到/tmp/gg,做初始化数据库

]# rpm --initdb --dbpath=/tmp/gg

 

实例:使用--dbpath指定数据库到/tmp/gg,重新构建数据库

]# rpm --rebuilddb --dbpath=/tmp/gg

 


rpm

标签:配置文件   管理系统   源代码   数据库   二进制   包管理   

原文地址:http://kening.blog.51cto.com/10985929/1727005

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!