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


相关文章
|
4月前
|
Ubuntu Linux
计算机基础知识:linux系统怎么安装?
在虚拟机软件中创建一个新的虚拟机,并选择相应操作系统类型和硬盘空间大小等参数。将下载的 ISO 镜像文件加载到虚拟机中。启动虚拟机,进入安装界面,并按照步骤进行安装。安装完成后,可以在虚拟机中使用 Linux 系统。
|
4月前
|
Ubuntu Linux
任何Ubuntu用户都应安装的四大Linux应用程序
当然,这款程序不需要太多介绍。我们面对的是网上最庞大最完整的多媒体中心,由于丰富的插件,我们能够高度细化地定制其每一项功能。这是我们的Linux发行版不可或缺的必备软件。 我们可以通过运行以下命令来轻松安装Kodi:sudo apt install kodi。
|
4月前
|
Ubuntu 物联网 Linux
从零安装一个Linux操作系统几种方法,以Ubuntu18.04为例
一切就绪后,我们就可以安装操作系统了。当系统通过优盘引导起来之后,我们就可以看到跟虚拟机中一样的安装向导了。之后,大家按照虚拟机中的顺序安装即可。 好了,今天主要介绍了Ubuntu Server版操作系统的安装过程,关于如何使用该操作系统,及操作系统更深层的原理,还请关注本号及相关圈子。
|
4月前
|
Ubuntu Linux 网络安全
Linux服务器之Ubuntu的安装与配置
Ubuntu Desktop是目前最成功、最流行的图形界面的Linux发行版;而Ubuntu Server也在服务器端市场占据了较大的份额。今天为大家详细介绍了Ubuntu Server的安装与配置,希望对你能有所帮助。关于VMware、VirtualBox等虚拟化软件的使用,朱哥还会在后续的文章中为大家详细介绍,敬请关注!
|
2月前
|
安全 Linux iOS开发
Nessus Professional 10.10 Auto Installer for RHEL 10, AlmaLinux 10, Rocky Linux 10 - Nessus 自动化安装程序
Nessus Professional 10.10 Auto Installer for RHEL 10, AlmaLinux 10, Rocky Linux 10 - Nessus 自动化安装程序
149 6
Nessus Professional 10.10 Auto Installer for RHEL 10, AlmaLinux 10, Rocky Linux 10 - Nessus 自动化安装程序
|
2月前
|
消息中间件 Kafka Linux
Linux下安装Kafka 3.9.1
本文介绍Kafka 3.9.1版本的安装与配置,包括通过ZooKeeper或KRaft模式启动Kafka。涵盖环境变量设置、日志路径修改、集群UUID生成、存储格式化及服务启停操作,适用于Linux环境下的部署实践。
238 0
|
4月前
|
网络协议 关系型数据库 Linux
【App Service Linux】在Linux App Service中安装 tcpdump 并抓取网络包
在App Service for Linux环境中,无法像Windows一样直接使用网络排查工具抓包。本文介绍了如何通过TCPDUMP在Linux环境下抓取网络包,包括SSH进入容器、安装tcpdump、执行抓包命令及下载分析文件的完整操作步骤。
203 5
|
4月前
|
弹性计算 安全 Linux
阿里云服务器ECS安装宝塔Linux面板、安装网站(新手图文教程)
本教程详解如何在阿里云服务器上安装宝塔Linux面板,涵盖ECS服务器手动安装步骤,包括系统准备、远程连接、安装命令执行、端口开放及LNMP环境部署,手把手引导用户快速搭建网站环境。
|
4月前
|
Ubuntu 安全 Linux
Linux这5款微型发行版,体积小+精简,比win7运行还快,值得安装
以上5款微型发行版体积小且精简,如果你有台旧电脑,不妨试试?