rpm包管理

一、概述

RPM 是RPM Package Manager(RPM软件包管理器)的缩写。由redhat公司的Redhat package manager改名而来,成了RedHat的工业标准

二、rpm的命名格式:

rpm包的命名格式:name-version-relase.arch.rpm

version: major.minor.release,同源代码

release: rpm自身的发行号,与程序源码的发行号无关,仅用于标识对rpm包不同制作的修订;同时,release还包含此包适用的OS

如:

arch: 适用于的硬件平台,

x86: i386, i486, i586, i686等;

x86_64: x86_64

powerpc: ppc

noarch: 依赖于虚拟机

rubygems-1.3.7-5.el6.noarch.rpm

以下是子包

rubygems-devel-1.3.7-5.el6.noarch.rpm

三、获取rpm包的途径:

1、发行的光盘或站点服务器

镜像:

http://mirrors.163.com

http://mirrors.sohu.com

2、项目的官网

源代码

rpm包

3、第三方机构或个人的制作并公开发布的rpm包

http://rpmfind.net

http://rpm.pbone.net

4、可靠途径:EPEL

fedora 维护的:Fedora-EPEL

四、合法性验证

    包的制作者使用单向加密提取原始数据的特征码,而后使用自己的私钥加密这段特征码,附加原始数据后面。

验证过程:

前提:必须有可靠机制获取到包制作者的公钥;

1、使用制作者的公钥解密加密的特征码,能解密则意味着来源合法;

2、使用与制作者同样的意向加密算法提取原始数据的特征码,并与解密出来的特征作比对,相同,则意味着完整性没问题;

五、包管理器的使用

1、安装及重新安装

rpm [option]  package_file

-i:install
-v|vv|vvv : 详细信息|更详细|再详细
-h;hash,用#来表示进度,每个5%
--test: 仅作测试,没有真正执行安装
--nodeps: 忽略依赖关系
--replacepkgs:重新安装 (如果包的配置文件安装后曾被改动过,卸载时,此文件将不会卸载,而是被重命名并保留)

blob.png2、卸载

rpm [option] package_name

-e: erase
--nodeps: 忽略依赖关系

blob.png

3、升级程序包

rpm [option] package_file

-U:升级或安装 :有老版本,替换,没有就安装。
-F:纯升级:一定要有有老版本,才会安装新版本
--force: 强制升级

注意:不应该对内核执行升级操作,而是安装。系统允许多内核并存;

升级完后新内核不支持。可能启动不了。

安装后新内核不能用,还可以启用老版本。

4、查询操作

rpm -q package_name : 查询包是否安装
rpm -qa : 查询所有已经安装的包
rpm -qi package_name: 查询包的描述信息
rpm -ql package_name: 查询包生成了哪些文件
rpm -qc package_name: 查询包安装生成了哪些配置文件
rpm -qd package_name: 查询包安装生成了哪些帮助文档
rpm -q --scripts package_name: 查询包的相关脚本(安装及卸载前后四类脚本)
rpm -qf some_file: 查询文件是由哪个包安装生成

对尚未安装的包执行查询

rpm -qpi :将会生成的描述信息
rpm -qpl :将会生成的文件
rpm -qpc :将会生成的配置文件
rpm -qpd :将会生成的帮助文档

5、rpm包来源合法性及完整性校验:

系统上需要有包制作者的公钥:比如导入光盘上的公钥

rpm --import package_file 导入公钥
rpm -qa gpg-pubkey*   查看导入的公钥
rpm -qi gpg-pubkey-NAME 查看公钥的详细信息

blob.png

检查包的完整性:安装过程中自动执行

rpm -K package_file 只检查不安装
rpm --checksig package_file 只检查不安装
rpm -K --nodigest 不检查包完整性
rpm -K --nosignature 不检查来源合法性

6、数据库重建

数据库目录: /var/lib/rpm

rpm --initdb:初始化 如果事先没有库,会新建一个;如果有,则不新建
rpm --rebuilddb:重建 直接重建,覆盖原有的数据库

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

(0)
麦鲸麦鲸
上一篇 2015-10-05 22:34
下一篇 2015-10-07 12:02

相关推荐

  • linux系统从windows xp上同步时间

    最近公司客户的调度系统GPS天文时钟出现故障,导致整个调度系统失去时间源,时间积累误差达十几分钟。去现场更换时钟很不方便,所有就想用现场的一台win xp(可上网)的远程机器做NTPserver,然后给linux系统对时。上网查了好多资料,终于找到了一个有效的解决方案,具体内容和步骤如下:首先下载一个Windows下的NTP服务软件。这个软件可以搭建wind…

    Linux干货 2015-03-27
  • 磁盘管理—MBR分区与GPT分区总结

    描述: 1,什么是磁盘分区   磁盘分区是使用分区编辑器(partition editor)在磁盘上划分几个逻辑部分,盘片一旦划分成数个分区(Partition),不同类的目录与文件可以存储进不同的分区。 2,硬盘结构及参数   3D参数(Disk Geometry):CHS(Cylinder/Head/Sector)  &nb…

    Linux干货 2016-08-29
  • 初入LINUX之首周总结及虚拟机的安装

    一.初入LINUX   1.在接触LINUX之前,先了解了计算机的系统组成: 2.服务器是计算机的一种,是网络中为客户端计算机提供各种服务的高性能的计算机,服务器在网络操作系统的控制下,将与其相连的硬盘磁带,打印机及昂贵的专用通讯设备提供给网络上的客户站点共享,也能为网络用户提供集中计算、信息发布及数据管理等服务 。 3.服务器的三大操作系统:①w…

    2017-05-20
  • class15磁盘管理(二) 高级磁盘管理(一)

    挂载点和/etc/fstab 配置文件系统体系 被mount、fsck和其它程序使用 系统重启时保留文件系统体系 可以在设备栏使用文件系统卷标 使用mount -a命令挂载  /etc/fstab 中的所有文件系统 文件挂载配置文件 /etc/fstab每行定义一个要挂载的文件系统;   &nbsp…

    Linux干货 2016-09-05
  • 设计模式概论

    1. 设计模式        设计模式(Design pattern)是一套被反复使用、多数人知晓的、经过分类编目的、代码设计经验的总结。使用设计模式是为了可重用代码、让代码更容易被他人理解、保证代码可靠性。 毫无疑问,设计模式于己于他人于系统都是多赢的,设计模式使代码编制真正工程化,设计模式是软件工程的基石,如同大厦…

    Linux干货 2015-06-18
  • HTTP响应连接介绍

    HTTP即超文本传输协议,web站点的实现就是基于HTTP协议得以实现。本文将详细讨论HTTP。 1. HTTP协议版本: HTTP从诞生到现在一共有如下几个版本: HTTP 0.9:是最早的版本,为HTTP的原型版本,其功能非常简陋; HTTP 1.0:此版本增加了很多新特性,如cache,method,MIME等,MIME的出现让网页不再是单纯的纯文本界…

    2017-05-31