软件的安装: 编译安装和包管理器安装有什么优势和劣势

在 Linux 上安装程序大概有 2 种思路

  • 直接编译源代码;
  • 使用包管理器。

包管理器使用

Linux 下的应用程序多数以软件包的形式发布,用户拿到对应的包之后,使用包管理器进行安装, Linux 下两大主流的包管理器为rpm和dpkg。

  • dpkg(debian package),是linux一个主流的社区分支开发出来的。社区就是开源社区,有很多世界顶级的程序员会在社区贡献代码,比如 github。一般衍生于debian的 Linux 版本都支持dpkg,比如ubuntu
  • rpm(redhatpackage manager)。在正式讲解之前,我们先来聊聊 RedHat 这家公司。
    • RedHat 是一个做 Linux 的公司,你可以把它理解成一家“保险公司”。 很多公司购买红帽的服务,是为了给自己的业务上一个保险。以防万一哪天公司内部搞不定 Linux 底层,或者底层有 Bug,再或者底层不适合当下的业务发展,需要修改等问题,红帽的工程师都可以帮企业解决。
    • 再比如,RedHat 收购了JBoss,把 JBoss 改名为 WildFly。 像 WildFly 这种工具更多是面向企业级,比如没有大量研发团队的企业会更倾向使用成熟的技术。RedHat 公司也有自己的 Linux,就叫作 RedHat。RedHat 系比较重要的 Linux 有 RedHat/Fedora 等。
  • 无论是dpkg还是rpm都抽象了自己的包格式,就是以.dpkg或者.rpm结尾的文件。
  • dpkg和rpm也都提供了类似的能力:
    • 查询是否已经安装了某个软件包;
    • 查询目前安装了什么软件包;
    • 给定一个软件包,进行安装;
    • 删除一个安装好的软件包。

yum和apt

自动依赖管理

  • Linux 是一个开源生态,因此工具非常多。
  • 工具在给用户使用之前,需要先打成dpkg或者rpm包。
  • 有的时候一个包会依赖很多其他的包,而dpkg和rpm不会对这种情况进行管理,有时候为了装一个包需要先装十几个依赖的包,过程非常艰辛!因此现在多数情况都在用yum和apt。

yum

  • 你可能会说,我不用yum也不用apt,我只用docker。首先给你一个连击 666,然后我还是要告诉你,如果你做docker镜像,那么还是要用到yum和apt,因此还是有必要学一下。
  • yum的全名是 Yellodog Updator,Modified。
  • 看名字就知道它是基于Yellodog Updator这款软件修改而来的一个工具。
  • yum是 Python 开发的,提供的是rpm包,因此只有redhat系的 Linux,比如 Fedora,Centos 支持yum。
  • yum的主要能力就是帮你解决下载和依赖两个问题。
  • 下载之所以是问题,是因为 Linux 生态非常庞大,有时候用户不知道该去哪里下载一款工具。
  • 比如用户想安装vim,只需要输入sudo yum install vim就可以安装了。yum的服务器收集了很多linux软件,因此yum会帮助用户找到vim的包。
  • 另一方面,yum帮助用户解决了很多依赖,比如用户安装一个软件依赖了 10 个其他的软件,yum会把这 11 个软件一次性的装好。
  • 关于yum的具体用法,可以使用man工具进行学习。

apt

  • apt全名是 Advanced Packaging Tools,是一个debian及其衍生 Linux 系统下的包管理器。
  • 由于advanced(先进)是相对于dpkg而言的,因此它也能够提供和yum类似的下载和依赖管理能力
  • 比如在没有vim的机器上,我们可以用下面的指令安装vim。sudo apt install vim

  • 然后用dpkg指令查看 vim 的状态是ii。第一个i代表期望状态是已安装,第二个i代表实际状态是已安装。
  • 卸载vim,再通过dpkg查看,如下图所示:sudo remove vim, dpkg -l vim

  • 我们看到 vim 的状态从ii变成了rc,r是期望删除,c是实际上还有配置文件遗留。
  • 如果我们想彻底删除配置文件,可以使用apt purge,就是彻底清除的意思。

  • 再使用dpkg -l时,vim已经清除了。

  • 期待结果是u就是 unkonw (未知)说明已经没有了。实际结果是n,就是 not-installed(未安装)。

 

如果想查询mysql相关的包,可以使用apt serach mysql,这样会看到很多和mysql相关的包,如下图所示:

  • 如果我们想精确查找一个叫作mysql-server的包,可以用apt list mysql-server

  • 这里我们找到了mysql-server包。

 

编译安装 Nginx

  • 接下来我们说说编译安装 Nginx(发音是 engine X),是一个家喻户晓的 Web 服务器。 它的发明者是俄国的伊戈尔·赛索耶夫。赛索耶夫 2002 年开始写 Nginx,主要目的是解决同一个互联网节点同时进入大量并发请求的问题。注意,大量并发请求不是大量 QPS 的意思,QPS 是吞吐量大,需要快速响应,而高并发时则需要合理安排任务调度。
  • 后来塞索耶夫成立了 Nginx 公司, 2018 年估值到达到 4.3 亿美金。现在基本上国内大厂的 Web 服务器都是基于 Nginx,只不过进行了特殊的修改,比如淘宝用 Tengine。

第一步: 下载源码

使用wget下载nginx源码包::wget http://nginx.org/download/nginx-1.19.2.tar.gz
第二步: 解压下载好的nginx包

  • tar -zxcf nginx-1.19.2.tar.gz
  • t代表tape(磁带);
  • ar是 archive(档案)。因为早期的存储介质很小,人们习惯把文件打包然后存储到磁带上,那时候unix用的命令就是tar。因为linux是个开源生态,所以就沿袭下来继续使用tar。
  • -x代表 extract(提取)。
  • -z代表gzip,也就是解压gz类型的文件。
  • -v代表 verbose(显示细节),如果你不输入-v,就不会打印解压过程了。
  • -f代表 file,这里指的是要操作文件,而不是磁带。
  • 所以tar解压通常带有x和f,打包通常是c就是 create 的意思

第三步:配置和解决依赖。解压完,我们进入nginx的目录看一看

configure文件是可执行文件,然后我们执行 configure 文件进行配置,这个配置文件来自一款叫作autoconf的工具,也是 GNU 项目下的,说白了就是bash(Bourne Shell)下的安装打包工具(就是个安装程序)。这个安装程序支持很多配置,你可以用./configure --help看到所有的配置项,如下图所示:

  •  这里有几个非常重要的配置项,叫作prefix。
  • prefix配置项决定了软件的安装目录。
  • 如果不配置这个配置项,就会使用默认的安装目录。
  • sbin-path决定了nginx的可执行文件的位置。
  • conf-path决定了nginx配置文件的位置。我们都使用默认,然后执行./configure,如下图所示:

 我们看到配置程序开始执行。但是最终报了一个错误,如下图所示

  • 报错的内容是,nginx的HTTP rewrite模块,需要PCRE库。
  • PCRE 是perl语言的兼容正则表达式库。
  • perl语言一直以支持原生正则表达式,而受到广大编程爱好者的喜爱。
  • 我曾经看到过一个 IBM 的朋友用perl加上wget就实现了一个简单的爬虫。接下来,我们开始安装PCRE。 
  • 一般这种依赖库,会叫pcre-dev或者libpcre。用apt查询了一下,然后grep。
  • 看到有pcre2也有pcre3。这个时候可以考虑试试pcre3。
  • 安装完成之后再试试./configure,提示还需要zlib。然后我们用类似的方法解决zlib依赖。zlib包的名字叫zlib1g, sudo apt install zlib1g-dev
  • 再尝试配置,终于配置成功了

第四步:编译和安装。

  • 通常配置完之后,我们输入make && sudo make install进行编译和安装。
  • make是linux下面一个强大的构建工具。
  • autoconf也就是./configure会在当前目录下生成一个 MakeFile 文件
  • make会根据MakeFile文件编译整个项目。
  • 编译完成后,能够形成和当前操作系统以及 CPU 指令集兼容的二进制可执行文件。
  • 然后再用make install安装。&&符号代表执行完make再去执行sudo make install。

为什么会有编译安装?

  • 原来使用 C/C++ 写的程序存在一个交叉编译的问题。
  • 就是写一次程序,在很多个平台执行。
  • 而不同指令集的 CPU 指令,还有操作系统的可执行文件格式是不同的。
  • 因此,这里有非常多的现实问题需要解决。一般是由操作系统的提供方,比如 RedHat 来牵头解决这些问题。
  • 你可以用apt等工具提供给用户已经编译好的包。apt会自动根据用户的平台类型选择不同的包。
  • 但如果某个包没有在平台侧注册,也没有提供某个 Linux 平台的软件包,我们就需要回退到编译安装,通过源代码直接在某个平台安装。

编译安装和包管理安装有什么优势和劣势了吗?

包管理安装很方便,但是有两点劣势。

  • 第一点是需要提前将包编译好,因此有一个发布的过程,如果某个包没有发布版本,或者在某个平台上找不到对应的发布版本,就需要编译安装。
  • 第二点就是如果一个软件的定制程度很高,可能会在编译阶段传入参数,比如利用configure传入配置参数,这种时候就需要编译安装。
  • 6
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值