软件管理
软件包的途径
软件包管理的职责
- 将二进制程序,库文件,配置文件,帮助文件打包成一个文件;
- 安装软件时按需将二进制文件,库文件,配置文件,帮助文件放到相应的位置;
- 生成数据库,追踪所安装的每一个文件;
- 软件卸载时根据安装时生成的数据库将对应的文件删除
软件包管理的核心功能
- 制作软件包
- 安装软件
- 卸载软件
- 升级软件
- 查询软件
- 校验软件
软件包管理
软件包分类
软件包管理工具
软件安装方式
- 通过前端工具安装
- 通过后端工具安装
- 编译安装
rpm包命名规范
[外链图片转存失败(img-b1hQqURu-1563377675264)(https://s2.ax1x.com/2019/04/23/EErG2q.jpg)]
rpm包管理
什么是rpm包及其作用
rpm是Redhat Package Manager的简称,用于管理软件包。 rpm有一个强大的数据库/var/lib/rpm。 rpm的管理工作包括软件的安装、卸载、升级、查询、校验、重建数据库、验证软件包来源合法性等等。
rpm包安装
语法: rpm -ivh /PATH/TO/PACKAGE_FILE …
常用选项:
-i: 安装
-v: 显示详细信息
-h: 显示安装进度条
–test: 测试安装,但不真正执行安装过程
–nodeps: 忽略依赖关系
–replacepkgs: 重新安装,替换原有安装
–oldpackage: 降级
–force: 强行安装,可以实现重装或降级
–nodigest: 不检查包的完整性
–nosignature: 不检查包的来源合法性
–noscripts: 不执行程序包脚本片断
%pre:安装前脚本 --nopre
%post:安装后脚本 --nopost
%preun:卸载前脚本 --nopreun
%postun:卸载后脚本 --nopostun
安装软件包, 需要指定软件包绝对路径
[root@zhoulijie ~]# rpm -ivh /mnt/cdrom/Packages/vsftpd-3.0.2-22.el7.x86_64.rpm
警告:/mnt/cdrom/Packages/vsftpd-3.0.2-22.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
准备中... ################################# [100%]
正在升级/安装...
1:vsftpd-3.0.2-22.el7 ################################# [100%]
在软件包所在目录下可以不指定绝对路径
[root@zhoulijie ~]# cd /mnt/cdrom/Packages/
[root@zhoulijie Packages]# rpm -ivh tree-1.6.0-10.el7.x86_64.rpm
警告:tree-1.6.0-10.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
准备中... ################################# [100%]
正在升级/安装...
1:tree-1.6.0-10.el7 ################################# [100%]
测试一个软件包是否能在该系统上安装
[root@zhoulijie Packages]# rpm -ivh --test vsftpd-3.0.2-22.el7.x86_64.rpm
警告:/mnt/cdrom/Packages/vsftpd-3.0.2-22.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
准备中... ################################# [100%]
软件包 vsftpd-3.0.2-22.el7.x86_64 已经安装
如果软件包存在, 强制再次安装
[root@zhoulijie Packages]# rpm -ivh --force vsftpd-3.0.2-22.el7.x86_64.rpm
警告:vsftpd-3.0.2-22.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
准备中... ################################# [100%]
正在升级/安装...
1:vsftpd-3.0.2-22.el7 ################################# [100%]
安装samba服务需要依赖其他组件, 使用–nodeps可重新强制安装
[root@zhoulijie Packages]# rpm -ivh --nodeps tree-1.6.0-10.el7.x86_64.rpm
警告:tree-1.6.0-10.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
准备中... ################################# [100%]
软件包 tree-1.6.0-10.el7.x86_64 已经安装
rpm包查询
rpm -q PACKAGE_NAME //查询指定的包是否已安装
rpm -qa //查询已经安装的所有包
rpm -qi PACKAGE_NAME //查询指定包的说明信息
rpm -ql PACKAGE_NAME //查询指定软件包安装后生成的文件列表
rpm -qf /path/to/somefile //查询指定的文件是由哪个rpm包安装生成的
rpm -qc PACKAGE_NAME //查询指定包安装的配置文件
rpm -qd PACKAGE_NAME //查询指定包安装的帮助文件
rpm -q --scripts PACKAGE_NAME //查询指定包中包含的脚本
rpm -q --whatprovides CAPABILITY //查询指定的CAPABILITY(能力)由哪个包所提供
如:rpm -q --whatprovides /bin/cat
rpm -q --whatrequires CAPABILITY //查询指定的CAPABILITY被哪个包所依赖
rpm -q --changelog COMMAND //查询COMMAND的制作日志
rpm -q --scripts PACKAGE_NAME //查询指定软件包包含的所有脚本文件
rpm -qR PACKAGE_NAME //查询指定的软件包所依赖的CAPABILITY
rpm -q --provides PACKAGE_NAME //列出指定软件包所提供的CAPABILITY
rpm -qpi /PATH/TO/PACKAGE_FILE //查询指定未安装包的说明信息
rpm -qpl /PATH/TO/PACKAGE_FILE //查询未安装的软件包会产生哪些文件
查询vsftpd这个rpm包是否安装
[root@zhoulijie Packages]# rpm -q vsftpd
vsftpd-3.0.2-22.el7.x86_64
模糊查找系统已安装的rpm包
[root@zhoulijie Packages]# rpm -qa |grep vsftpd
vsftpd-3.0.2-22.el7.x86_64
查询vsftpd软件包的相关信息
[root@zhoulijie Packages]# rpm -qi vsftpd
Name : vsftpd
Version : 3.0.2
Release : 22.el7
Architecture: x86_64
Install Date: 2019年04月23日 星期二 21时46分42秒
Group : System Environment/Daemons
Size : 356220
License : GPLv2 with exceptions
Signature : RSA/SHA256, 2017年03月23日 星期四 22时25分48秒, Key ID 199e2f91fd431d51
Source RPM : vsftpd-3.0.2-22.el7.src.rpm
Build Date : 2017年03月23日 星期四 22时01分19秒
Build Host : x86-034.build.eng.bos.redhat.com
Relocations : (not relocatable)
Packager : Red Hat, Inc. <http://bugzilla.redhat.com/bugzilla>
Vendor : Red Hat, Inc.
URL : https://security.appspot.com/vsftpd.html
Summary : Very Secure Ftp Daemon
Description :
vsftpd is a Very Secure FTP daemon. It was written completely from
scratch.
查询rpm包所安装的文件
[root@zhoulijie Packages]# rpm -ql vsftpd
/etc/logrotate.d/vsftpd
/etc/pam.d/vsftpd
/etc/vsftpd
/etc/vsftpd/ftpusers
/etc/vsftpd/user_list
/etc/vsftpd/vsftpd.conf
/etc/vsftpd/vsftpd_conf_migrate.sh
。。。。。。省略以下。。。。。。。。
查询rpm包相关的配置文件
[root@zhoulijie Packages]# rpm -qc vsftpd
/etc/logrotate.d/vsftpd
/etc/pam.d/vsftpd
/etc/vsftpd/ftpusers
/etc/vsftpd/user_list
/etc/vsftpd/vsftpd.conf
查询配置文件或命令来自于哪个rpm包
[root@zhoulijie Packages]# rpm -qf /etc/vsftpd/vsftpd.conf
vsftpd-3.0.2-22.el7.x86_64
[root@zhoulijie Packages]# rpm -qf /usr/sbin/vsftpd
vsftpd-3.0.2-22.el7.x86_64
查询未安装的软件包会产生哪些文件
[root@zhoulijie Packages]# rpm -qlp vsftpd-3.0.2-22.el7.x86_64.rpm
警告:vsftpd-3.0.2-22.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
/etc/logrotate.d/vsftpd
/etc/pam.d/vsftpd
/etc/vsftpd
/etc/vsftpd/ftpusers
/etc/vsftpd/user_list
/etc/vsftpd/vsftpd.conf
/etc/vsftpd/vsftpd_conf_migrate.sh
/usr/lib/systemd/system-generators/vsftpd-generator
。。。。。。省略以下。。。。。。。。
查询未安装的软件说明信息
[root@zhoulijie Packages]# rpm -qip vsftpd-3.0.2-22.el7.x86_64.rpm
警告:vsftpd-3.0.2-22.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
Name : vsftpd
Version : 3.0.2
Release : 22.el7
Architecture: x86_64
Install Date: (not installed)
Group : System Environment/Daemons
Size : 356220
License : GPLv2 with exceptions
Signature : RSA/SHA256, 2017年03月23日 星期四 22时25分48秒, Key ID 199e2f91fd431d51
Source RPM : vsftpd-3.0.2-22.el7.src.rpm
Build Date : 2017年03月23日 星期四 22时01分19秒
Build Host : x86-034.build.eng.bos.redhat.com
Relocations : (not relocatable)
Packager : Red Hat, Inc. <http://bugzilla.redhat.com/bugzilla>
Vendor : Red Hat, Inc.
URL : https://security.appspot.com/vsftpd.html
Summary : Very Secure Ftp Daemon
Description :
vsftpd is a Very Secure FTP daemon. It was written completely from
scratch.
rpm包升级
rpm -Uvh /PATH/TO/NEW_PACKAGE_FILE //如果装有老版本的,则升级;否则,则安装
rpm -Fvh /PATH/TO/NEW_PACKAGE_FILE //如果装有老版本的,则升级;否则,退出
--oldpackage:降级
[root@zhoulijie Packages]# rpm -Uvh vsftpd-3.0.2-22.el7.x86_64.rpm
警告:vsftpd-3.0.2-22.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID fd431d51: NOKEY
准备中... ################################# [100%]
软件包 vsftpd-3.0.2-22.el7.x86_64 已经安装
rpm包卸载
//语法:rpm -e PACKAGE_NAME
//先查询, 然后卸载
[root@zhoulijie Packages]# rpm -qa | grep vsftpd
vsftpd-3.0.2-22.el7.x86_64
[root@zhoulijie Packages]# rpm -e vsftpd
**注意:**如果其他包依赖于要卸载的包,这个被依赖的包是无法卸载的,除非强制卸载,强制卸载后依赖于这个包的其他程序将无法正常工作
rpm包校验
// 如果执行以下命令无内容输出说明此包未被修改过
[root@localhost ~]# rpm -V vsftpd
S.5....T. c /etc/pam.d/vsftpd
.......T. c /etc/vsftpd/ftpusers
S.5....T. c /etc/vsftpd/vsftpd.conf
.M....... /var/ftp/pub
S //文件的容量大小是否被改变
M //文件的类型或者文件的属性是否被修改
5 //MD5这一种指纹加密的内容已经不同
D //装置的主/次代码已经改变
L //路径已经被改变
U //文件的所属主已被修改
G //文件的所属组已被修改
T //文件的创建时间已被改变
rpm重建数据库
数据库信息在/var/lib/rpm目录中
rpm --rebuilddb //重建数据库,一定会重新建立
rpm --initdb //初始化数据库,没有才建立,有就不用建立
检察软件包来源合法性和完整性
加密类型:
对称加密 //加密解密使用同一个密钥
公钥加密 //一对密钥,公钥和私钥。公钥隐含于私钥中,可以提取出来并公布出去
单向加密 //只能加密不能解密
/etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release //红帽官方公钥
rpm -K PACKAGE_FILE //检查指定包有无密钥信息
dsa,gpg //验证来源合法性,也即验证签名。可以使用--nosignatrue略过此项
sha1,md5 //验证软件包完整性。可以使用--nodigest略过此项
rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release //导入密钥文件
CentOS 7发行版光盘提供的密钥文件 //RPM-GPG-KEY-CentOS-7
练习
如何查询 util-linux 软件包安装了哪些文件?
[root@zhoulijie Packages]# rpm -ql util-linux
如何查询 mkdir 命令是由哪个 RPM 软件包安装的?
[root@zhoulijie Packages]# rpm -qf /usr/bin/mkdir
升级软件包时,-F、-U选项有何区别?
rpm -Uvh 如果装有老版本的,则升级;否则,则安装
rpm -Fvh 如果装有老版本的,则升级;否则,退出
如何检查vsftpd软件包是否安装?
[root@zhoulijie Packages]# rpm -q vsftpd
如何检查vsftpd软件包所有的文件存放目录?
[root@zhoulijie Packages]# rpm -ql vsftpd
如何检查vsftpd软件包的配置文件?
[root@zhoulijie Packages]# rpm -qc vsftpd
如何使用rpm安装vsftpd服务?
[root@zhoulijie Packages]# rpm -ivh vsftpd-3.0.2-22.el7.x86_64.rpm
如何使用rpm强制安装依赖包?
[root@zhoulijie Packages]# rpm -ivh --force vsftpd-3.0.2-22.el7.x86_64.rpm
如何使用rpm卸载vsftpd软件包?
[root@zhoulijie Packages]# rpm -e vsftpd
将本章学习到的rpm命令整理成一个列表,写明每个命令的作用
安装软件的命令格式 | rpm -ivh RPM安装包 |
---|---|
升级软件的命令格式 | rpm -Uvh RPM安装包 |
卸载软件的命令格式 | rpm -e RPM安装包 |
查询软件描述信息的命令格式 | rpm -qpi RPM安装包 |
列出软件文件信息的命令格式 | rpm -qpl RPM安装包 |
查询文件属于哪个RPM的命令格式 | rpm -qf RPM安装包 |