linux应用程序安装与管理-3

 

目录

3. 升级、卸载RPM软件包

1)安装、升级软件包

2)卸载软件包

4.维护RPM数据库

1)重建RPM数据库

2)导入验证公钥


3. 升级、卸载RPM软件包

系统管理工作中,安装、升级及卸载软件包是管理应用程序最基本的工作内容。使用rpm命令实现这些操作时,基本的命令选项如下所述。

  • -i:在当前系统中安装(Install)一个新的RPM软件包。
  • -e:卸载指定名称的软件包。
  • -U:检查并升级系统中的某个软件包,若该软件包原来并未安装,则等同于 "-i" 选项。
  • -F:检查并重新系统中的某个软件包,若该软件包原来并未安装,则放弃安装。
  • -h:在安装或升级软件包的过程中,以 "#" 号显示安装进度。
  • -v:显示软件安装过程中的详细信息。
  • --force:强制安装某个软件包,当需要替换已安装的软件包及文件,或者安装一个比当前使用的软件版本更旧的软件时,可以使用此选项。
  • --nodeps在安装或升级、卸载一个软件包时,不检查与其他软件包的依赖关系。

1)安装、升级软件包

使用rpm命令安装软件包时,一般需要指定完整的软件包文件名作为参数(可以有多个);而卸载软件包时,只需要指定软件名称即可。若要一次安装多个RPM软件包,可以使用通配符这 种方式在安装存在相互依赖关系的多个软件包时特别有用,系统将会自动检查依赖性并决定安装顺 序,而无须管理员去判断应该先装哪一个包。

在安装一个新的软件包时,通常使用 "-ivh" 的组合选项,这样便于了解软件安装的过程信息, 及时跟踪安装进度。若使用新版本的软件包替换旧的版本,则只需将 "-i" 换成 "-U" 即可。例如, 以下操作将从光盘目录中全新安装lynx软件包。

[root@localhost ~]# umount /dev/cdrom

[root@localhost ~]# mount /dev/cdrom /media/

mount: /dev/sr0 写保护,将以只读方式挂载

[root@localhost ~]# mkdir /pack

[root@localhost ~]# cp -rf /media/Packages/* /pack/

[root@localhost ~]# ls /pack/

389-ds-base-1.3.5.10-11.el7.x86_64.rpm

389-ds-base-libs-1.3.5.10-11.el7.x86_64.rpm

abattis-cantarell-fonts-0.0.16-3.el7.noarch.rpm

abrt-2.1.11-45.el7.centos.x86_64.rpm

abrt-addon-ccpp-2.1.11-45.el7.centos.x86_64.rpm

……//省略部分

[root@localhost ~]# rpm -ivh /pack/lynx-2.8.8-0.3.dev15.el7.x86_64.rpm

警告:/pack/lynx-2.8.8-0.3.dev15.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID f4a80eb5: NOKEY

准备中...                          ################################# [100%]

正在升级/安装...

   1:lynx-2.8.8-0.3.dev15.el7         ################################# [100%]

[root@localhost ~]# rpm -q lynx

lynx-2.8.8-0.3.dev15.el7.x86_64

[root@localhost ~]# which lynx

/usr/bin/lynx

使用lynx命令程序可以在文本模式中访问Web站点(不能显示图片,若当前终端不支持中文, 则中文也无法正常显示),也可以直接查看本机中的".html"格式的各种软件文档。

2)卸载软件包

卸载一个软件包时,主要使用 "-e" 选项。例如,执行" rpm -e lynx " 操作可卸载已安装的 lynx软件,再执行查询时会发现lynx软件没有安装,具体操作如下:

[root@localhost ~]# rpm -e lynx

[root@localhost ~]# rpm -q lynx

未安装软件包 lynx

当需要安装、卸载一个与其他程序存在依赖关系的软件包时,系统将提示存在依赖关系而放弃执行。这时可以结合 "--nodeps" 选项忽略依赖关系,而强行安装或卸载指定的软件包。忽略依赖关系可能会导致软件功能异常或失效,因此只在学习或者调试程序时使用,生产环境中应避免使用。

4.维护RPM数据库

1)重建RPM数据库

RPM数据库用于记录在Linux操作系统中安装、卸载、升级应用程序的相关信息,由RPM软件包管理系统自动完成维护,一般不需要用户干预。当RPM数据库发生损坏(可能由误删文件、非法关机、病毒破坏等导致),且Linux操作系统无法自动完成修复时,将导致无法使用rpm命令正常地安装、卸载及查询软件包。这时可以使用rpm 命令的 "--rebuilddb" 或 "--initdb" 功能对RPM 数据库进行重建,具体操作如下:

[root@localhost ~]# rpm --rebuilddb

或者:

[root@localhost ~]# rpm --initdb

2)导入验证公钥

在Linux/UNIX应用领域,相当一部分软件厂商会对发布的软件包进行数字签名,以确保软件的完整性、合法性。对于用户来说,可以利用官方提供的公钥文件,自动对下载的软件包进行验证,若在安装软件时出现验证失败的提示,则表示该软件包可能已经被非法篡改。

CentOS的DVD光盘中默认已经提供了用于数字签名验证的公钥文件,即位于光盘根目录下的RPM-GPG-KEY-CentOS-7RPM-GPG-KEY-CentOS-Testing-7文件。在没有导入公钥文件之前,安装CentOS光盘中的一部分RPM 软件包时,可能会出现 "警告:/pack/lynx-2.8.8-0.3.dev15.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID f4a80eb5: NOKEY" 的警告信息(一般不影响正常使用)。

向RPM数据库中导入公钥文件时,需要用到 "--import" 选项。例如,执行以下操作可以把光盘目录中的RPM-GPG-KEY-CentOS-7公钥文件导入RPM数据库中。

[root@localhost ~]# ls /media/

CentOS_BuildTag  GPL       LiveOS    RPM-GPG-KEY-CentOS-7

EFI              images    Packages  RPM-GPG-KEY-CentOS-Testing-7

EULA             isolinux  repodata  TRANS.TBL

[root@localhost ~]# cp /media/RPM-GPG-KEY-CentOS-7 /pack/

[root@localhost ~]# cp /media/RPM-GPG-KEY-CentOS-Testing-7 /pack/

[root@localhost ~]# rpm --import /pack/RPM-GPG-KEY-CentOS-7

[root@localhost ~]# rpm --import /pack/RPM-GPG-KEY-CentOS-Testing-7

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值