如何在Linux中安装软件

时间:2024-04-13 20:21:41

文章目录

  • 一、Linux应用程序基础
    • 1.Linux软件安装包分类
    • 2.应用程序和系统命令的关系
    • 3.常见的软件包的封装类型
  • 二、安装软件的方式
    • 1.RPM包管理工具
    • 2.yum安装
    • 3.编译


一、Linux应用程序基础

1.Linux软件安装包分类

Linux源码包:
实际上,源码包就是一大堆源代码程序,是由程序员按照特定的格式和语法编写出来的。
Linux二进制包:
二进制包,也就是源码包经过成功编译之后产生的包。由于二进制包在发布之前就已经完成了编译的工作,因此用户安装软件的速度较快,且安装过程报错几率大大减小。

2.应用程序和系统命令的关系

因素 区别
位置 命令的存储位置和应用程序储存的位置不一样
用途 命令主要用于处理系统的基本操作;应用程序可以完成独立的任务,如浏览器访问网页
使用环境 命令用于字符界面 ;应用程序用于字符和桌面
格式 命令有固定的格式和命令参数;应用程序无固定格式

3.常见的软件包的封装类型

文件类型 保存目录
RPM软件包 扩展名为“.rpm”
DEB软件包 扩展名为“.deb”
源代码软件包 一般为“.tar.gz”、“.tar.bz2”等格式的压缩包 包含程序的原始代码

二、安装软件的方式

1.RPM包管理工具

这个工具由Red Hat公司提出,被众多Linux发行版所采用,该工具会建立统一的数据库文件,详细记录软件包安装、卸载等变化信息,自动分析软件包依赖关系。
在这里插入图片描述
安装软件包时,会自动分析软件包的依赖关系,但不会自动解决,需要人工手动解决,比较麻烦。一般不建议采用此类方法安装软件,通常我们是用该工具去查询系统中安装的软件和软件状态。

RPM软件命令

选项 效果
rpm -qa(all) 显示当前系统中以 RPM 方式安装的所有软件列表
rpm -q 软件名 查询指定软件是否已安装
rpm -qi 软件名 查看指定软件包的名称、版本、许可协议、用途描述等详细信息
rpm -ql(list) 软件名 显示指定的软件包在当前系统中安装的所有目录、文件列表
rpm -qc (configfiles) 软件名 列出已安装的指定软件的配置文

在这里插入图片描述
RPM安装命令

选项 效果
i install 安装
v 显示过程
h 人性化显示 ##########进度条
e+软件名 卸载软件
- -nodeps 在安装或升级、卸载一个软件包时,不检查与其他包的依赖关系
- -force 强制安装某个软件包

维护RPM数据库
1.重建RPM数据库
当RPM 数据库发生损坏,可通过重建RPM 数据库修复
rpm --rebuild 或者 rpm --initdb

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

2.yum安装

yum安装的优缺点:
优点:1.简单
2.自动解决依赖关系
缺点:1.需要有服务端
2.yum只会将最常用的功能编译进去,可能会导致功能不全
3.版本过旧,更新速度慢

rpm是单机安装,而yum是需要依靠网络,想要安装需要保证你的网络要通畅才行。
1.如何去寻找yum安装包?
yum安装,数据包不在本地,网络上有yum服务器,我们要让客户端知道怎么去服务端。
通过书写客户端配置文件,来让客户端去往服务端。
客户端配置文件要求:
1.必须在 /etc/yum.repos.d/这个目录下
2.配置文件必须以*.repo结尾
配置文件内容:

配置文件的内容(默写)
[base] #仓库的描述(可以用字符自定义)
name= #仓库的名字,不要重复,可以自定义(字母)
baseurl= 网址 #指明服务器的位置,去服务器端下载软件包(百度查找地址)
enabled=1 #是否开启仓库 为0即不开启 默认选项为1 (可以不写)
gpgcheck=1 #开启包的验证 如果是0代表关闭包的验证(一般不启用包的验证)
gpgkey= #密钥的位置
在这里插入图片描述
在这里插入图片描述

gpgcheck的作用:检验包的安全性,完整性
防止别有用心的人再包中加入病毒,密钥对比,如果和红帽的密钥不一致就会不安装。
服务器端:
1.提供安装包
2.元信息(即类似目录 理解为数据库:安装包的路径、安装包的依赖关系)
安装过程简图
在这里插入图片描述
单机yum仓库
在没有网络的情况下使用,自己既是服务端,又是客户端。将带有软件安装包的光驱挂载到一个文件夹。
客户端:写配置文件
本地yum仓库过程
mount /dev/sr0 /mnt #挂载提供安装包和原信息
cd /etc/yum.repos.d #切换到指定目录,写配置文件
mkdir bak #建立子文件夹
mv *.repo bak #移走网络源
vim local.repo #建立本地配置文件

[local]
name=local
baseurl=file:///mnt
gpgcheck =0
wq

yum clean all #清除以前的缓存
yum makecache #下载原信息

yum install tree-y#安装tree
yum remove tree -y #卸载tree
yum install epel-release.noarch -y#安装额外源

yum命令

命令 效果
yum list 显示所有安装包
yum install +软件包 安装软件
yum remove 软件包 卸载软件 (单独卸载这个包,不会卸载依赖关系的软件包)
yum provides +关键字 找到安装包

在这里插入图片描述

3.编译

编译安装的优缺点
优点:1.功能自定义
2.版本可以安装最新的版本
缺点:安装复杂

编译安装前准备:
1.先安装编译软件 编译软件也有依赖关系需要手动解决
2.下载安装包
3.解压安装包

3步安装
./configure 脚本文件,源码包中自带
功能:
1.检测安装环境
2.可以选择安装软件的功能并生成一个文件make.file,按照这个文件的配置进行编译安装
3.指定安装路径 --prefix =路径 路径可以不存在,会自动建立
默认在/usr/local/nginx
make #将源代码编译成二进制可执行的文件 在objs下
make install #将软件安装进系统指定路径

示例:编译安装ngnix网站软件
yum -y install gcc gcc-c++ make pcre-devel expat-devel perl pcre apr*#安装依赖环境
mkdir /bianyi
cd /bianyi
wget http://nginx.org/download/nginx-1.18.0.tar.gz#下载源码包
tar xf nginx-1.18.0.tar.gz#解压
cd nginx-1.18.0
./configure --prefix=/apps/nginx检测环境,指定安装目录
make -j2#两个核心编译
make install#将软件复制到前面规定的路径
ln -s /apps/nginx/sbin/nginx /usr/local/sbin/#软链接,目的是可以补全。
测试:关闭防火墙,查询虚拟机,用IP地址访问
在这里插入图片描述
出现该界面即可。