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

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

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-7和RPM-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


下面依次介绍Apache的基本安装过程、使用方法。


1.解包

开源软件的源代码包一般为TarBall形式,扩展名为 ".tar.gz" 或 ".tar.bz2",都可以使用tar命令进行解压释放。对于只有 ".gz"扩展名的源代码包,表示只经过压缩而并未使用tar归档,这样的文件只需使用gzip进行解压缩即可。在Linux操作系统中,通常将各种软件的源代码目录保存到 "/usr/src/"目录中,以便于集中管理。释放后的软件包目录一般包括软件名和版本信息(如httpd-2.4.25)。解包前先安装编译环境和依赖包。


以下操作将把httpd-2.4.25.tar.gz文件解包到 /usr/src/ 目录中。


[root@localhost ~]# tar zxf httpd-2.4.25.tar.gz -C /usr/src/


[root@localhost ~]# ls /usr/src


debug  httpd-2.4.25  kernels


相关文章
|
1月前
|
Linux
手把手教会你安装Linux系统
手把手教会你安装Linux系统
|
24天前
|
Linux 测试技术 网络安全
Linux系统之安装OneNav个人书签管理器
【10月更文挑战第19天】Linux系统之安装OneNav个人书签管理器
41 5
Linux系统之安装OneNav个人书签管理器
|
6天前
|
缓存 Linux 开发者
Linux内核中的并发控制机制:深入理解与应用####
【10月更文挑战第21天】 本文旨在为读者提供一个全面的指南,探讨Linux操作系统中用于实现多线程和进程间同步的关键技术——并发控制机制。通过剖析互斥锁、自旋锁、读写锁等核心概念及其在实际场景中的应用,本文将帮助开发者更好地理解和运用这些工具来构建高效且稳定的应用程序。 ####
23 5
|
26天前
|
监控 Java Linux
Linux系统之安装Ward服务器监控工具
【10月更文挑战第17天】Linux系统之安装Ward服务器监控工具
50 5
Linux系统之安装Ward服务器监控工具
|
8天前
|
存储 安全 数据管理
如何在 Rocky Linux 8 上安装和配置 Elasticsearch
本文详细介绍了在 Rocky Linux 8 上安装和配置 Elasticsearch 的步骤,包括添加仓库、安装 Elasticsearch、配置文件修改、设置内存和文件描述符、启动和验证 Elasticsearch,以及常见问题的解决方法。通过这些步骤,你可以快速搭建起这个强大的分布式搜索和分析引擎。
21 5
|
28天前
|
JSON JavaScript Linux
Linux系统之安装cook菜谱工具
【10月更文挑战第15天】Linux系统之安装cook菜谱工具
34 2
Linux系统之安装cook菜谱工具
|
30天前
|
Ubuntu Linux 测试技术
Linux系统之Ubuntu安装cockpit管理工具
【10月更文挑战第13天】Linux系统之Ubuntu安装cockpit管理工具
111 4
Linux系统之Ubuntu安装cockpit管理工具
|
1月前
|
Linux 网络安全 数据安全/隐私保护
Linux系统之Centos7安装cockpit图形管理界面
【10月更文挑战第12天】Linux系统之Centos7安装cockpit图形管理界面
69 1
Linux系统之Centos7安装cockpit图形管理界面
|
20天前
|
消息中间件 Linux RocketMQ
在Red Hat Enterprise Linux 9上使用Docker快速安装并部署
通过以上步骤,你可以在Red Hat Enterprise Linux 9上使用Docker快速安装并部署RocketMQ。这种方法不仅简化了安装过程,还提供了一个灵活的环境来管理和扩展消息队列系统。RocketMQ作为一款高性能的分布式消息系统,通过Docker可以实现快速部署和高效管理。
48 2
|
21天前
|
消息中间件 Linux RocketMQ
在Red Hat Enterprise Linux 9上使用Docker快速安装并部署
通过以上步骤,你可以在Red Hat Enterprise Linux 9上使用Docker快速安装并部署RocketMQ。这种方法不仅简化了安装过程,还提供了一个灵活的环境来管理和扩展消息队列系统。RocketMQ作为一款高性能的分布式消息系统,通过Docker可以实现快速部署和高效管理。
30 3