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


相关文章
|
2天前
|
Oracle 关系型数据库 Linux
linux8安装oracle 11g遇到的问题记录
Oracle 11g在Linux 8上安装时会遇到link编译环节的问题。官方建议忽略安装中的链接错误,安装完成后应用DBPSU 11.2.0.4.240716补丁及一次性补丁33991024,再重新编译二进制文件,并配置监听器和数据库。但因11g已退出服务期,这些补丁需付费获取。网上信息显示22年1月的PSU补丁也可解决问题,找到该补丁后按常规方式打补丁即可。如有需求或疑问可咨询我。
33 20
|
22天前
|
Linux Python
Linux 安装python3.7.6
本教程介绍在Linux系统上安装Python 3.7.6的步骤。首先使用`yum`安装依赖环境,包括zlib、openssl等开发库。接着通过`wget`下载Python 3.7.6源码包并解压。创建目标文件夹`/usr/local/python3`后,进入解压目录执行配置、编译和安装命令。最后设置软链接,使`python3`和`pip3`命令生效。
|
25天前
|
Ubuntu Linux
Linux 各发行版安装 ping 命令指南
如何在不同 Linux 发行版(Ubuntu/Debian、CentOS/RHEL/Fedora、Arch Linux、openSUSE、Alpine Linux)上安装 `ping` 命令,详细列出各发行版的安装步骤和验证方法,帮助系统管理员和网络工程师快速排查网络问题。
124 20
|
18天前
|
NoSQL 关系型数据库 MySQL
Linux安装jdk、mysql、redis
Linux安装jdk、mysql、redis
148 7
|
25天前
|
Unix Linux 编译器
UNIX/Linux 上的安装
UNIX/Linux 上的安装。
40 2
|
3月前
|
Linux 测试技术 网络安全
Linux系统之安装OneNav个人书签管理器
【10月更文挑战第19天】Linux系统之安装OneNav个人书签管理器
125 5
Linux系统之安装OneNav个人书签管理器
|
2月前
|
NoSQL Linux PHP
如何在不同操作系统上安装 Redis 服务器,包括 Linux 和 Windows 的具体步骤
本文介绍了如何在不同操作系统上安装 Redis 服务器,包括 Linux 和 Windows 的具体步骤。接着,对比了两种常用的 PHP Redis 客户端扩展:PhpRedis 和 Predis,详细说明了它们的安装方法及优缺点。最后,提供了使用 PhpRedis 和 Predis 在 PHP 中连接 Redis 服务器及进行字符串、列表、集合和哈希等数据类型的基本操作示例。
86 4
|
3月前
|
监控 Java Linux
Linux系统之安装Ward服务器监控工具
【10月更文挑战第17天】Linux系统之安装Ward服务器监控工具
79 5
Linux系统之安装Ward服务器监控工具
|
2月前
|
缓存 Linux 开发者
Linux内核中的并发控制机制:深入理解与应用####
【10月更文挑战第21天】 本文旨在为读者提供一个全面的指南,探讨Linux操作系统中用于实现多线程和进程间同步的关键技术——并发控制机制。通过剖析互斥锁、自旋锁、读写锁等核心概念及其在实际场景中的应用,本文将帮助开发者更好地理解和运用这些工具来构建高效且稳定的应用程序。 ####
50 5
|
3月前
|
JSON JavaScript Linux
Linux系统之安装cook菜谱工具
【10月更文挑战第15天】Linux系统之安装cook菜谱工具
53 2
Linux系统之安装cook菜谱工具