前言
Linux平台上常见的软件包格式主要有三种,分别是源码格式包、通用二进制格式包和rpm格式包本文主要讲解rpm格式包安装及管理。RPM是Redhat Package Manager的缩写,是由Redhat公司开发的Linux软件包管理工具,因其便捷的管理方式与开源思想,逐渐被其他Linux发行商所采用,现已成Linux平台下通用的软件包管理方式。
rpm包的命名格式
name-version-release.arch.rpm
name:软件包名字
version:由主版本号.次版本号.发行号组成(同源代码包)
主版本号改变:重大改进
次版本号改变:某个子功能发生重大变化
发行号改变:修正了部分bug,调整了一点功能
release:rpm自身的发行号,与程序源码的发行号无关,仅用于标识对rpm包不同制作的修订;同时,release还包含此包适用的OS
arch:适用硬件平台
例如:httpd-2.2.15-39.el6.x86_64.rpm
一个程序有20个功能:常用功能有8个,特殊A:3个,特殊B:6个,二次开发相关功能:3个,而rpm包可能只包含其中的几个,所以如果有需要还需手动编译,在此略提一下。
分包机制
核心包,主包命名方式与源程序一致:
例如:httpd-2.2.15-39.el6.x86_64.rpm
子包:httpd-tools-2.2.15-39.el6.x86_64.rpm
OS Vendor: 系统发行商提供的包
获取rpm包的途径
1、发行的光盘或站点服务器
镜像:
http://mirrors.163.com
http://mirrors.sohu.com
2、项目的官网
源代码
rpm包
3、第三方机构或个人制作并公开发布的rpm包
http://rpmfind.net
http://rpm.pbone.net
可靠的途径:EPEL
Fedora-EPEL
rpm包的合法性验正
包的制作者使用单向加密提取原始数据的特征码,而后使用自己的私钥加密这段特性码,附加原始数据后面。通过验证可得知:rpm包来源合法性和完整性。
验正过程:
前提:必须通过可靠途径获取到包制作者的公钥。
1、使用制作者的公钥解密加密的特征码,能解密则意味着来源合法。
2、使用与制作者同样的单向加密算法提取原始数据的特征码,并与解密出来的特征作比对,相同,则意味着软件包完整。
导入: rpm --import /path/to/key_file #导入公钥 rpm -qa gpg-pubkey* #显示所有已经导入的gpg格式的公钥 rpm -qi gpg-pubkey-NAME #显示密钥详细信息 检查包:安装过程中会自动执行 手动检查: rpm -K /path/to/package_file rpm --checksig /path/to/package_file rpm -K --nodigest #不检查包完整性 rpm -K --nosignature #不检查来源合法性[object Object]
RPM管理之安装
命令格式:
rpm [option] /path/to/package_file
-i:安装 -v:显示详细信息 #想更详细显示可用-vv -vvv -h:显示安装进度 #一个“#”代表2% -ivh:一般组合使用 --test:测试安装 --nodepes:忽略依赖关系 #能安装上,但可能无法运行 --replacepkgs:重新安装 #如果原有配置文件作了修改,很有可能不执行替换,而是将生成的配置文件重命名为 .rpmnew
RPM管理之卸载
命令格式:
rpm [option] package_name
-e:卸载 --nodeps:忽略依赖关系 #能卸载,但依赖于此包程序包可能会运行不正常(建议一并卸载)
RPM管理之升级
-Uvh:升级或安装 #如果软件包没有安装则安装;否则,升级 -Fvh:升级 #需要升级的软件包必须已经安装 --force: 强制升级 #升级后可能存在版本冲突 注意:内核不应该直接升级,而是安装,系统允许多内核并存
RPM管理之查询
命令格式:
rpm [option] package_name
rpm -q package_name:查询某包是否安装
rpm -qa:查询所有已经安装的包 按条件过滤:rpm -qa | grep ‘PATTERN‘
rpm -qi package_name:查询包的描述信息
rpm -ql package_name:查询某包安装生成了哪些文件 rpm -qc package_name:查询某包安装生成了哪些配置文件 rpm -qd package_name:查询某包安装生成了哪些帮助文件
rpm -q --scripts package_name:查询程序包的相关脚本 #脚本有四类: preinstall:安装前脚本 postinstall: 安装后脚本 preuninstall: 卸载前脚本 postuninstall: 卸载后脚本 #
rpm -qf /path/to/some_file:查询某文件是由哪个包安装生成的
rpm {-qpi|-qpl|-qpc|-qpd} /path/to/package_file:对尚未安装的包执行查询
RPM管理之校验
命令格式:
rpm [option] package_name
rpm -V package_name:检查包安装生成的文件属性是否发生变化 #校验已安装的包的文件与保存在rpm数据库里的包的元数据,如果相同无任何显示, #如果不同则显示改变的地方,下面是每个字符代表的意义: #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 #手动改变httpd的文件
RPM管理之数据库重建
数据库目录:/var/lib/rpm
如果rpm的数据库损坏,会导致查询等相关操作无法正常进行,这时就需要重建数据库。
rpm --initdb:初始化 #如果事先没有数据库,会创建一个;如果有,则不创建 rpm --rebuilddb: 重建 #直接重建,覆盖原有的数据库
The end
好了,RMP管理就总结到这里,希望对新手有所帮助,以上仅个人学习整理,如有错漏,大神勿喷~~~
本文出自 “北城书生” 博客,请务必保留此出处http://scholar.blog.51cto.com/9985645/1625669
原文:http://scholar.blog.51cto.com/9985645/1625669