Linux的安装及管理程序(rpm和yum)

Linux应用程序基础

应用程序与系统命令的关系

1.系统命令

image.png
2.应用程序

image.png

典型应用程序的目录结构

image.png

常见的软件包封装类型

image.png

RPM包管理工具

简介

●RPM软件包管理器Red-Hat Package Manager

①由Red Hat公司提出,被众多Linux发行版所采用

②建立统一的文件数据库

③详细记录软件包安装、卸载、升级等变化信息

④自动分析软件包依赖关系

●RPM软件包

①软件素材参考:www.rpm.org

②一般命名格式:

image.png

el7代表centos 7系统

df -h 看光盘的软件包

Snipaste_2022-03-07_15-41-49.png

将光盘挂载到mnt目录下

Snipaste_2022-03-07_15-43-14.png

查看光盘类型

Snipaste_2022-03-07_15-44-19.png

rpm命令的格式

rpm命令能实现几乎所有对RPM软件包的管理功能

执行”man rpm”命令可以获得关于rpm命令的详细帮助信息

●rpm命令功能

①查询、验证RPM软件包的相关信息

②安装、升级、卸载RPM软件包

③维护重建RPM数据库信息等综合管理操作

查询已安装的rpm软件信息

image.png

  • rpm -q 软件名 # ——查询指定软件是否已安装

  • rpm -qi 软件名 # ——显示已安装的指定软件的详细信息

  • rpm -ql 软件名 # ——显示已安装的指定软件的文件列表

  • rpm -qc 软件名 # ——列出已安装的指定软件的配置文件

  • rpm -qd 软件名 # ——列出已安装的指定软件的软件包文档所在的位置

  • rpm -qR 软件名#——列出已安装的指定软件的依赖的软件包及文件

  • rpm -qf 文件或目录 # ——查询已安装的指定软件属于哪个安装包

  • rpm -qa # ——显示当前系统中以 rpm方式安装的所有软件列表

  • rpm -qa | grep -i postfix # ——查询软件postfix是否已安装

-q 查询指定软件是否已安装

Snipaste_2022-03-07_15-50-18.png

-qa 再用grep过滤掉其他安装rpm的软件列表

Snipaste_2022-03-07_15-51-34.png

-qi 显示已安装的指定软件的详细信息

Snipaste_2022-03-07_15-52-31.png

-ql 显示已安装的指定软件的文件列表

Snipaste_2022-03-07_15-53-11.png

-qc 列出已安装的指定软件的配置文件

Snipaste_2022-03-07_15-53-42.png

-qd 列出已安装的指定软件的软件包文档所在的位置

Snipaste_2022-03-07_15-54-31.png

-qR 列出已安装的指定软件的依赖的软件包及文件

Snipaste_2022-03-07_15-55-17.png

-qf 查询已安装的指定软件属于哪个安装包

Snipaste_2022-03-07_15-58-51.png

查询RPM 软件包文件中信息

image.png

  • rpm -qpi RPM包文件名 # ——查询指定软件包的详细信息

  • rpm -qpl RPM包文件名 # ——查询指定软件包的文件列表

  • rpm -qpc RPM包文件名 # ——查询指定软件包的配置文件

  • rpm -qpd RPM包文件名 # ——查询指定软件包的软件包文档的位

安装、升级、卸载 RPM 软件包

●格式:

1.rpm [选项] RPM包文件

2.rpm -ivh RPM软件包

●常用选项:

①-i:安装一个新的 RPM 软件包。

②-U:升级某个软件包,若未安装过,则进行安装。

③-F:升级某个软件包,若未安装过,则放弃安装。

④-h:在安装或升级软件包的过程中,以“#”号显示安装进度。

⑤-v:显示软件安装过程中的详细信息。

⑥- -force:强制安装某个软件包,比如要安装版本更旧的软件包。

⑦-e:卸载指定名称的软件包。

⑧- -nodeps:在安装或升级、卸载一个软件包时,不检查与其他软件包的依赖关系。

Snipaste_2022-03-07_16-06-30.png

维护RPM数据库

1.重建 RPM 数据库

●当 RPM 数据库发生损坏,可通过重建RPM数据库修复

rpm –rebuilddb 或者 rpm –initdb

2.导入验证公钥

●在没有导入用于数字签名验证的公钥文件之前,安装光盘中的一部分RPM软件包时会报错。需要向RPM数据库中导入位于光盘根目录下的公钥文件

1.mount /dev/sr0 /mnt/

2.rpm –import /mnt/RPM-GPG-KEY-CentOS-7

安装源代码软件包需要编译安装,需要安装支持c和c++程序语言的编译器,如gcc、gcc-c++、make

如果使用rpm方式安装,则需要先安装多个依赖包,这样会很繁琐。这里可以使用 yum方式进行一键安装。

解决软件包依赖关系方法

安装有依赖关系的多个软件时

被依赖的软件包需要先安装

可同时指定多个.rpm包文件进行安装

卸载有依赖关系的多个软件时

依赖其他程序的软件包需要先卸载

可同时指定多个软件名进行卸载

忽略依赖关系

结合“–nodeps”选项,但可能导致软件异常

指定多个.rpm包文件进行安装

[root@localhost Packages]##rpm -ivh
复制代码

yum配置

配置本地yum源仓库

mount /dev/cdrom /mnt/                # ——把光盘挂载到/mnt目录下

cd /etc/yum.repos.d/
mkdir repos.bak
mv *.repo repos.bak

cd /etc/yum.repos.d/
vim local.repo
[local]                                # ——仓库类别
name=local                            # ——仓库名称
baseurl=file:///mnt                    # ——指定URL 访问路径为光盘挂载目录
enabled=1                             # ——开启此yum源,此为默认项,可省略
gpgcheck=0                            # ——不验证软件包的签名

yum clean all && yum makecache        # ——删除yum缓存并更新
yum clean                          ● 可以拆分成两个步骤来进行
yun makecache
复制代码

Snipaste_2022-03-07_16-17-03.png

Snipaste_2022-03-07_16-16-29.png

Snipaste_2022-03-07_16-18-48.png

yum的常用操作命令

yum -y install 软件名                # ——安装、升级软件包,“-y”选项表示自动确认
yum -y remove 软件名                    # ——卸载软件包,可自动解决其依赖关系
yum -y update 软件名                    # ——升级软件包

yum list                            # ——查询软件包列表
yum list installed                    # ——查询系统中已安装的软件包
yum list available                    # ——查询仓库中尚未安装的软件包
yum list updates                    #  ——查询可以升级版本的软件包

yum info 软件名                        #    ——查询软件包的描述信息
yum info httpd

yum search [all] 关键词                # ——根据某个关键词来查找相关的软件包
yum search all httpd

yum whatprovides 命令                # ——查询命令属于哪个软件包
yum whatprovides netstat
复制代码

使用yum方式进行安装

yum install -y gcc gcc-c++ make
复制代码
© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享