linux要编译源码的原因是什么

服务器   发布日期:2023年09月05日   浏览次数:331

本篇内容介绍了“linux要编译源码的原因是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

原因:1、Linux发型版本众多,但是每个版本采用的软件或者内核版本都不一样,而二进制包所依赖的环境不一定能够正常运行,所以大部分软件直接提供源码进行编译安装。2、方便定制,满足不同的需求。3、方便运维、开发人员维护;源码是可以打包二进制的,但是对于这个软件的打包都会有一份代价不小的额外工作,包括维护,所以如果是源码的话,软件产商会直接维护。

linux为什么要编译源码

一般来说,我们软件的安装方式有yum(rpm),和源码编译两种方式,那么为什么我们需要源码编译安装一部分软件?选择源码编译安装软件有以下几个原因:

  • 满足不同的运行平台,我们Linux发型版本众多,但是每个版本采用的软件或者内核版本都不一样,而我们的二进制包所依赖的环境不一定能够正常运行,所以大部分软件直接提供源码!

  • 方便定制,满足不同的需求,很多时候我们所需要的软件都是可以定制的,我需要什么就安装什么,大多数二进制代码都是一键装全,所以自由度并不高!

  • 方便运维、开发人员维护,我们的源码是可以打包二进制的,但是对于这个软件的打包都会有一份代价不小的额外工作,包括维护,所以如果是源码的话,软件产商会直接维护,但是如果是二进制的话,一般都是Linux发行商提供。

linux编译源码教程

Linux上几乎所有的软件都经过了GPL授权,因此几乎所有的软件都会提供源码。

而一个软件要在Linux上执行,必须是二进制文件,因此当我们拿到软件源码后,需要将它编译成二进制文件才能在Linux上运行。

1、软件编译过程

将源码编译成可供Linux运行的二进制文件一共需要两步:

  • 使用gcc编译器将源码编译成目标文件

  • 再次使用gcc编译器将目标文件链接成二进制文件

这过程看似简单,实则不然。一个软件的源代码往往被封装在多个源文件中,此外这些文件有错综复杂的依赖关系,编译需要严格按照指定的顺序进行,这无疑增加了编译的难度。好在make命令可以帮助我们简化编译过程。

整个编译过程被浓缩在Makefile文件中(告诉make命令需要怎么去编译和链接程序),当执行make命令时,make会去当前目录中寻找Makefile文件,并根据该文件中的要求完成整个编译过程。

而Makefile文件由configure命令产生。当执行configure命令时,configure会根据当前系统环境动态生成一个适合本系统的Makefile文件,供make命令使用。

2、Linux源码安装步骤

  • 获取源码
    将软件的源码下载至/usr/local/,并解压。

  • 查看INSTALL与README文件
    解压后查看INSTALL与README文件,这两个文件中详细介绍了本软件的安装方法和注意事项。

  • 创建Makefile文件
    执行configure命令,生成Makefile文件。

  • 编译
    执行make clean;make命令将源码编译成二进制文件。
    PS:make clean命令用来清除上一次编译生成的目标文件。这个步骤可有可无,但为了确保编译的成功,还是加上为好。防止由于软件中含有残留的目标文件导致编译失败。

  • 安装
    执行make install命令将上一步编译好的二进制文件安装到指定的目录中去。

3、安装演示

1)进入/usr/local/,并创建memcached目录:

cd /usr/local/
mkdir memcached

2)下载memcached的源码

wget http://memcached.org/files/memcached-1.4.29.tar.gz

3)解压源码

tar -zxvf memcached-1.4.29.tar.gz

4)执行configure,生成Makefile文件

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

此时当前目录下将会生成一个Makefile文件。

注意:

以上就是linux要编译源码的原因是什么的详细内容,更多关于linux要编译源码的原因是什么的资料请关注九品源码其它相关文章!