RPM简介:
`RPM(Revolutions Per Minute)是由RedHalt公司发展而来的,它是以数据库记录的方式将我们所需的
软件安装在Linux操作系统上,也就是说制作者将源码包在指定的硬件环境及操作系统上进行编译,将源代码
编译成二进制文件,并生成默认的数据库文件,其中记录了安装程序包所依赖的软件,最后将可执
行文件及数据库文件打包成RPM机制的文件,这大大的让我们对文件管理方便起来,试想一下,
如果没有该工具,我们自己去编译源代码,那涉及到的依赖很多,那是不是特别麻烦,卸载起来也特别的麻烦
不利于管理,为了解决这类问题,后就诞生了RPM程序包管理器,在Linux界主流的其主要有RPM及DPKG,
这里只介绍RPM程序包管理器`
8.png
9.png
RPM用法及相关命令
用法:
QUERYING AND VERIFYING PACKAGES:
rpm {-q|--query} [select-options] [query-options]
`select-options:查询包`
` query-options:查询配置文件、版本号等`
rpm {-V|--verify} [select-options] [verify-options]
`校验`
rpm --import PUBKEY ...
`导入密钥认证`
rpm {-K|--checksig} [--nosignature] [--nodigest] PACKAGE_FILE...
`手动验证包的合法性`
`选项(select):
PACKAGE_NAME:查询指定包
-a, --all:查询所有已经安装的包
-f, --file FILE:查询文件属于哪个包
-g, --group GROUP:查询指定包组中含有哪些程序包
-p, --package PACKAGE_FILE:查询为安装的包包含哪些文件
--whatprovides CAPABILITY:查询指定的包提供了哪些能力
--whatrequires CAPABILITY:查询指定的CAPABILITY被哪些程序包所依赖
`
示例:
rpm -q httpd:查询httpd包
rpm -qa:查询所有安装的程序包
rpm -qf /etc/fstab:查询fstab配置文件属于哪个包
rmp -pg “System Environment/Daemons”:查询该包组包含哪些程序包
rpm -q --whatprovides httpd:查询httpd功能是由哪个包提供的
rpm -q --whatrequires httpd:查询httpd功能被哪个程序包依赖
`选项(query):
--changelog:查询包的更改信息
-d, --docfiles:查询包的文档文件
-c, --configfiles:查询包的配置文件
-i, --info:查询包的基本信息,版本号、包名、大小、描述信息等
-l, --list:查询包的所有文件
--provides:查询包所提供的能力
-R, --requires:查询包的依赖关系
--scripts:查询包所需要的执行脚本
`
示例:
rpm -q --changelog httpd:查询httpd包更改的信息
rpm -qd httpd:查询httpd所提供的文档
rpm -qc httpd:查询httpd的配置文件
rpm -ql httpd:查询httpd中所有的文件
rpm -qi httpd:查询httpd包的基本信息
rpm -qR httpd:查询httpd包的依赖关系
rpm -q --scripts:查询httpd包内部所需要运行的脚本
`选项(VERIFY)
rpm {-V|--verify} [select-options] [verify-options]
在安装程序包后,假如是在网上随意下载的一个包进行安装,有可能这个包被人篡改过或做过
一些不好的手段,这是我们需要校验该包,判断该包是否被更改过,以下为检查包更过过的说明
`
S | 检查文件大小是否一致 |
---|---|
M | 判断可执行等参数是否被改变(权限、文件类型等) |
5 | 判断加密的属性是否被改变 |
D | 判断主设备或副设备号是否匹配 |
L | 路径是否匹配 |
U | 所属者是否改变 |
G | 所属组是否改变 |
T | 包创建的时间是否改变 |
P | 包所提供的能力是否改变 |
导入公钥密码
rpm --import PUBKEY ...
示例:rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6
`isntall(安装)`
用法:
rpm {-i|--install} [install-options] PACKAGE_FILE ...
`安装`
rpm {-U|--upgrade} [install-options] PACKAGE_FILE ...
`升级或安装`
rpm {-F|--freshen} [install-options] PACKAGE_FILE ...
`升级`
rpm {-i|--install} [install-options] PACKAGE_FILE ...
Optiosn:
`
-i:安装
-v:查看更详细的安装信息
-h:显示安装进度
--test:测试,不是真正的安装
--nodeps:忽略包依赖关系
--replacepkg:重新安装包,如果之前包的相关文件存在则不会替换,不存在则提供
--nosigature:不检查包的签名及包来源的合法性
--nodigest:不检查包的完整性
--justab:由于RPM数据库损坏或某些缘故产生错误,可以使用giant选项来更新软件在数据库内的相关信息
preinstall:安装过程开始之前运行的脚本,%pre,--nopre
postinstall:安装过程完成之后运行的脚本,%post,--nopost
preuninstall:卸载过程真正执行之前运行的脚本,%preun ,--nopreun
postuninstall:卸载过程完成之后运行的脚本,%postun,--nopostun
`
示例:
rpm -ivh /media/CentOS_6.10_Final/Packages/httpd-2.2.15-69.el6.centos.x86_64.rpm:安装httpd包
rpm -ivh --test /media/CentOS_6.10_Final/Packages/httpd-2.2.15-69.el6.centos.x86_64.rpm:测试安装
rpm -ivh --nodeps /media/CentOS_6.10_Final/Packages/httpd-2.2.15-69.el6.centos.x86_64.rpm:安装时忽略依赖关系
rpm -ivh --nosigature /media/CentOS_6.10_Final/Packages/httpd-2.2.15-69.el6.centos.x86_64.rpm:不检查包的签名及来源合法性
rpm -ivh --replacepkg /media/CentOS_6.10_Final/Packages/httpd-2.2.15-69.el6.centos.x86_64.rpm:重新安装httpd包
`rpm {-U|--upgrade} [install-options] PACKAGE_FILE ...:升级安装,如果程序包不存在则安装,存在则升级`
Options:
`
-U:升级安装
--oldpackage:降级安装
-F:升级
--force:强制升级
`
(卸载)
rpm {-e|--erase} [--allmatches] [--nodeps] [--noscripts][--notriggers] [--test] PACKAGE_NAME ...
Options:
`
-e:卸载程序包
--allmatches:卸载所有指定名称的各程序包版本
--nodeps:忽略依赖关系
--test:测试卸载
注意:卸载安装的过程一定要右上至下解除关系,当要卸载指定的程序包时,一定要先卸载
指定的程序包,否则会发生结构上的问题,这就好比拆房子,先拆最上面。
`
网友评论