Linux 安装软件的几种方式

这篇具有很好参考价值的文章主要介绍了Linux 安装软件的几种方式。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

哈喽大家好,我是咸鱼

相信小伙伴们都知道在 Linux 中,安装软件一般有三种方式

  • yum 安装
  • rpm 安装
  • 源码编译安装

咸鱼平时三种安装方式都会用,但是具体原理和区别却没有去深入了解过

结果上周部门刚来的新人问我这几种安装方式的时候,一下子把我问懵了

那么今天咸鱼将会向小伙伴们介绍这三种软件安装方式的原理以及各自的优缺点

源码编译安装

首先我们来看源码编译安装,这是 Linux 中最传统的软件安装方式

我们知道在 Linux 中,安装好的软件通常是以可执行文件的形式提供的

这些可执行文件是经过编译的二进制程序,其本质上是由计算机可以直接执行的机器指令组成的

而二进制程序可以直接在 Linux 系统上运行,执行相应的功能

# 可以用 file 工具来查看
[root@minion2 ~]# file /bin/bash
/bin/bash: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.32, BuildID[sha1]=85e3da5a087950e7aaeb7893c056218a8874d2e5, stripped

"ELF 64-bit LSB executable" 时,表示该文件是一个 64 位的 ELF 可执行文件

“源码”就是源代码,源代码其实就是一般的纯文本文件,我们编写好“源码”之后,需要将这个文本文件“编译”成为操作系统看得懂的二进制程序,这个“编译”的过程就需要”编译器“来实现

比如说我们使用 Linux 的标准程序语言 C 来写一个源代码,然后用 C 语言编译器 gcc 来编译,就可以制作一个可执行二进制程序

有时候我们会在程序当中调用外部子程序,或是利用其他软件提供的函数,这个时候我们就需要在编译的过程中将对应的函数库加进去,这样编译器就可以将源代码与函数库作一个链接(link)

Linux 安装软件的几种方式

make 与 makefile

我们在用 gcc 这类编译器进行编译的时候,需要手动指定要编译的每个源代码文件以及相关的编译选项(如编译模式、优化级别等)

编译小型程序还好,如果碰到包含大量源代码的程序就会导致编译过程往往极为复杂(例如需要手动管理依赖关系和编译顺序)

那么我们可以使用 make 来进行编译,make 能够根据代码文件之间的依赖关系自动执行必要的编译和链接操作,简化编译过程

当执行 make 命令时,make 会在当前目录下查找 makefile 这个文件(makefile 里面记录了源代码该如何编译的详细信息)

通常软件开发商会写一个检测用户操作环境以及当前操作环境是否有软件开发商所需要的其他功能的程序,这个检测程序一般命名为 configconfigure

检测程序执行完毕之后就会主动建立出一个 makefile 文件

通常检测的内容如下:

  1. 是否有适合的编译器可以编译该软件的代码
  2. 是否已经存在该软件所需要的函数库或其他依赖条件
  3. 操作系统是否适合该软件
  4. 内核的头文件是否存在

makefile 是一种文本文件,它包含了一组规则和指令,用于告诉 make 工具如何编译和链接源代码文件,生成可执行程序或库文件等

#来看一个 makefile 简单例子
[root@root ~]# cat makefile
main: main.o haha.o sin_value.o cos_value.o
    gcc -o main main.o haha.o sin_value.o cos_value.o -lm
clean:
    rm -f main main.o haha.o sin_value.o cos_value.o

Tarball(压缩文件)

前面我们已经知道,源代码其实就是纯文本文件,我们想要安装一款软件,就需要去官网下载这些源码到本地

但是这样是很浪费带宽和消耗网络资源的(纯文本文件在网络上是很浪费带宽的一种文件格式)

所以如果能够把这些源码将其打包和压缩,不但能够让用户方便下载,还能减轻官网的网络带宽, Tarball 文件由此诞生

所谓的 Tarball 文件,就是将软件的所有源码先用 tar 打包,然后再压缩(最常见的就是 gzip 压缩技术),所以 Tarball 文件一般的扩展名会写成 *.tar.gz*.tgz
Linux 安装软件的几种方式
所以我们常见的安装方式过程如下:

  1. 从官网下载 Tarball 软件包,放在 /usr/local/src 目录下解压缩
  2. 解压缩之后进入到软件目录,查看 INSTALLREADME 等相关文件内容,然后安装好一些依赖的软件
  3. 建立 makefile,通过自动检测程序(configconfigure)生成 makefile 文件
  4. 使用 make 命令进行编译
  5. 最后 make install 安装

我们以安装 nginx 为例

1、首先从官网下载 Tarball 文件到相关目录

cd /usr/local/src && \
wget http://nginx.org/download/nginx-1.15.4.tar.gz

2、然后安装相关的依赖软件

yum -y install gcc openssl-devel pcre-devel zlib-devel

3、对 Tarball 文件解压缩,并进入文件目录

tar -zxvf nginx-1.15.4.tar.gz -C /usr/local
cd /usr/local/nginx-1.15.4

4、建立 makefile(指定了安装目录 /usr/local/nginx

./configure --prefix=/usr/local/nginx

5、编译以及安装

make && make install

总结一下

  • 源代码大多为纯文本文件,需要通过编译器的编译操作后,才能够生成操作系统看得懂的可执行二进制文件
  • 可以通过 make 和 makefile 来简化编译流程
  • makefile 包含了一组规则和指令,由自动检测程序(configconfigure)生成
  • 为了方便用户下载和检测软件官网的压力,一般通过 Tarball 的方式来管理软件

rpm 安装

前面我们讲到了源码编译安装,即通过下载软件发行商提供的 Tarball 文件来进行安装

将 Tarball 文件下载之后还要解压缩,还要 configure 检测,还要编译还要配置还要安装,可以看到过程是比较复杂的,需要敲的命令比较多,很容易劝退小白

不但如此,这种安装方式还会导致一些其他问题

  • 依赖性问题: 软件通常依赖于其他软件库和组件,手动解决依赖性问题可能会变得非常棘手,特别是当软件的依赖关系相对复杂时
  • 版本控制: 用户需要自行管理多个软件的不同版本,这可能导致版本冲突和不一致
  • 一致性问题: 用户需要花费大量时间来确保所有安装的软件都保持一致,并避免不同版本之间的冲突

为了能够更好地更加标准地管理 Linux 的软件,减轻用户的负担和学习成本,厂商们就在想:我们能不能先把软件所有的相关文件都打包成一个特殊格式的软件包(文件)

然后在这个软件包里面不但包含了检测依赖关系和系统环境的文件,还包含了关于这个软件的信息、二进制文件等等

这样当用户下载了这个软件包的时候,只需要简单的命令就能够安装,并且还会把当前软件的信息管理起来,方便用户后续的升级、卸载等操作

于是 Red Hat 在 1995 年引入了 RPM (RedHat Package Manager)

RPM 是以一种数据库记录的方式来将你所需要的软件安装到你的 Linux 系统的一套管理机制

1、厂商们先把软件编译好,然后打包成 RPM 包(包含软件的依赖关系、版本信息以及其他元数据)

2、当你在安装 RPM 包的时候,系统会检查该软件包的依赖的其他软件包是否已经安装

3、然后检查本地没有已经安装好的软件或者冲突的版本(有的话会给提示)

Linux 安装软件的几种方式
4、如果上面两项检查都通过了,系统会将安装的软件包的信息添加到 RPM 数据库中,以便后续的管理和查询

5、安装完成后,系统会更新 RPM 数据库中的信息,标记软件包为已安装状态,并记录安装时间、版本等信息

我们来看一下常见的 rpm 命令有哪些

# 安装
rpm -i package

# 卸载
rpm -e package

# 卸载的时候不验证依赖
rpm -e --nodeps package

# 显示软件包的详细信息
rpm -qi package

# 列出已安装的软件包
rpm -qa

YUM 安装

前面我们介绍了 RPM 安装,尽管 RPM 可以处理软件的依赖关系,但仍有一定的局限性

比如依赖关系需要我们手动处理,RPM 不会帮我们自动下载安装所需要的依赖软件包,这就导致我们需要手动查找并下载软件包

为了解决这个问题,YUM(Yellowdog Updater, Modified)诞生了

YUM 基于 RPM 包去管理软件包,它通过一个名为 yum repository 的服务器存储库来管理软件包,其中包含了各种软件包及其依赖关系信息

这使得用户可以通过简单的命令完成软件包的安装、升级和卸载,同时自动处理依赖关系,无须繁琐地一次次下载、安装

Linux 安装软件的几种方式

虽然 YUM 最初是为 Red Hat Linux 开发的,但它的原理和功能非常通用,因此很多其他 Linux 发行版也采用了 YUM 作为其软件包管理工具

下面是一些 yum 常见命令

# 安装指定的软件包
yum install package
​
# 更新所有已安装的软件包到最新版本
yum update
​
# 更新指定安装包
yum upgrade package
​
# 卸载指定的软件包
yum remove package
​
# 显示有关指定软件包的详细信息
yum info package
​
# 列出所有已安装的软件包 
yum list
​
# 列出所有可用的软件包(在仓库中但尚未安装)
yum list available
​
# 清理 YUM 缓存,包括元数据和软件包
yum clean all

总结

最后我们总结一下

区别:

  • 源码编译安装需要手动下载源代码,解决依赖问题,配置编译选项,编译,安装,并且没有自动升级和卸载功能
  • RPM 软件包包含已经编译好的二进制程序、相关依赖关系信息以及软件信息等,减轻了软件安装复杂性,方便软件管理
  • YUM 软件包基于 RPM 包去管理软件包,进一步解决了软件依赖等问题,不同于 RPM 安装,YUM 安装能够自动解决软件包的依赖关系

各自优缺点:

  • 源码编译安装

    • 优点:灵活性高定制性强,可以根据需要自定义编译选项和功能;可以跨平台使用
    • 缺点:安装过程复杂;不能解决软件依赖问题;管理不方便,没有自动升级卸载机制
  • RPM 安装

    • 优点:管理方便,将软件以及相关信息打包成 RPM 形式,可以自动升级和卸载软件;可以轻松跟踪已安装的软件包、版本和更新信息;较好地解决软件依赖问题
    • 缺点:遇到软件依赖问题的时候,需要手动解决;不够灵活,不能够自定义功能
  • YUM 安装文章来源地址https://www.toymoban.com/news/detail-633169.html

    • 优点:自动解决软件包的依赖关系;管理方便,提供软件包的安装、升级、卸载和搜索等功能
    • 缺点:缺少定制化,不能自定义功能;更新滞后,某些发行版的官方仓库可能不及时提供最新版本的软件包

到了这里,关于Linux 安装软件的几种方式的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Linux查看进程实际占用内存的几种方式

    方式一 top -p pid RES :72296,使用的内存为72296kb %MEM:1.9,进程占用了总内存的1.9% 方式二 ps -aux | grep pid 显示其他用户启动的进程(a) 查看系统中属于自己的进程(x) 启动这个进程的用户和它启动的时间(u) 方式三 cat /proc/pid/status

    2024年02月11日
    浏览(45)
  • Linux下启动jar包的几种常见方式

    首先把这两个jar上传到linux ,会操作启动一个应用和同时启动多个应用 两个项目jar已上传,可去这里下载: https://download.csdn.net/download/zengzhaowu313/88411336 第一种、直接启动 jar 包  ,先启动一个应用程序 ,后面操作启动多个应用 java -jar Test001.jar # 缺点:当前 ssh 窗口会被锁定,

    2024年02月05日
    浏览(59)
  • Linux开机自动挂载文件系统的几种方式

    在Digitalocean上,给主机添加硬盘时,为了免去分区、格式化、挂载等麻烦,可以选择让运营商帮忙自动完成以上操作。 查看文档可知,运营商在添加硬盘时,在挂载阶段自动执行了以下脚本: 1). 创建挂载目录。 mkdir -p /mnt/volume 2). 挂载硬盘(临时挂载,主机重启后失效)。

    2024年02月09日
    浏览(45)
  • 限制登录Linux服务器的几种方式

    在日常运维中,我们通常使用防火墙iptables跟firewalld的方式来实现访问控制,但在实际环境中,开启防火墙可能会对业务造成影响,所以以下整理了三种限制登录Linux服务器的几种方式。分别是修改TCP Wrappers服务访问控制、修改sshd_config配置文件、防火墙策略iptables跟firewalld。

    2024年02月17日
    浏览(46)
  • Jenkins的几种安装方式以及邮件配置

    目录 Jenkins介绍 Jenkins下载、安装 一、通过war包安装 二、通过docker安装 jenkins 容器中添加 git, maven 等组件 jenkins 容器中的公钥私钥 在 jenkins 容器中调用 docker 简单的方式启动 Docker server REST API 一个 jenkins 示例 三、通过Homebrew安装 访问Jenkins、Jenkins配置 Jenkins配置邮件发送 Jen

    2024年02月16日
    浏览(38)
  • 【整理】jenkins插件安装的几种方式(在线安装、离线安装)

    整理参考:https://blog.csdn.net/qq_35472206/article/details/126049574 1、在线安装:安装jenkins后,初次启动的时候安装插件 安装推荐的插件,或者选择插件安装 2、在线安装:插件管理,可选插件中 3、离线安装:下载插件(.hpi格式) 使用该方法安装插件每次只能安装一个插件,且如果插

    2024年02月01日
    浏览(37)
  • linux下java项目在后台启动的几种方式

    在 Linux 下,Java 项目的后台启动方式有以下几种:         可以使用 nohup 命令启动 Java 应用程序,使其在后台运行,这样即使退出终端或关闭 SSH 连接,Java 应用程序也能继续运行。   使用 符号可以将 Java 应用程序放到后台运行。   可以使用 screen 命令创建一个虚拟终端

    2024年02月01日
    浏览(37)
  • Ubuntu物理机显卡驱动安装的几种方式

    参考Ubuntu16系统安装及初始化(SSH服务、网络配置) 1.1图形界面安装 搜索ubuntu自带的\\\"软件和更新\\\",点击“附加驱动”,选择合适的显卡驱动,点击“应用更改”。 (如果附加驱动列表为空,可以尝试更换网络源) 1.2命令行界面安装 (1)查看适合本显卡的驱动: ubuntu-drive

    2024年02月05日
    浏览(29)
  • Linux 下通过 java 命令启动 jar 包的几种常见方式

    Linux 下通过 java 命令启动 jar 包的几种常见方式 一、后台启动jar包命令 方法一:直接启动 jar 包服务 方法二:后台启动 jar 包服务 方法三:后台不挂断启动 方式四:指定日志输出的启动 方式五:指定配置文件启动 方式六:指定配置文件,使用系统默认的log配置,不另行指定

    2024年02月13日
    浏览(43)
  • 探讨手机越狱和安装deb文件的几种方式研究

    笔者近期为了测试某产品功能,需要越狱环境手机一枚,经过一番波折之后越狱成功,不过在安装deb文件时也发生了一些奇葩的问题,值得探讨,接下来,笔者就逐一记录,与君探讨。 基本概念: iOS越狱 - iOS系统是苹果手机封闭的系统,无法自由安装APP,但是在越狱之后,

    2024年02月06日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包