configure、make、make install 背后的原理

警告
本文最后更新于 2024-01-20,文中内容可能已过时。
1
2
3
./configure
make
make install

以上三个命令是源码安装软件的通用步骤。其主要完成以下工作:

  • ./configure: 配置,是用来检测你的安装平台的目标特征。比如它会检测你是不是有 CC 或 GCC,并不是需要 CC 或 GCC,它是个 shell 脚本。configure 脚本负责在使用的系统上准备好软件的构建环境。确保接下来的构建和安装过程所需要的依赖准备好,并且搞清楚使用这些依赖需要的东西。

  • make: 构建,用来编译,它从 Makefile 中读取指令,然后编译。下载的源码包一般没有一个最终的 Makefile 文件,一般是一个模版文件 http://Makefile.in 文件,然后 configure 根据系统的参数生成一个定制化的 Makefile 文件。这个过程会执行在 Makefile 文件中定义的一系列任务将软件源代码编译成可执行文件。

  • make install: 安装,它也从 Makefile 中读取指令,安装到指定的位置。make install 命令就是将可执行文件、第三方依赖包和文档复制到正确的路径。

tips

这些脚本是怎么产生的?

安装过程简单说就是 configure 脚本根据系统信息将 Makefile.in 模版文件转换为 Makefile 文件,但是 configure 和 Makefile.in 文件是怎么产生的呢?

如果你曾经试着打开 configure 或者 Makefile.in 文件,你会发现超长而且复杂的 shell 脚本语言。有时候这些脚本代码比它们要安装的程序源代码还要长。

如果想手动创建一个这样的 configure 脚本文件是非常可怕的,好消息是这些脚本是通过代码生成的。

通过这种方式构建的软件通常是通过一个叫做 autotools 的工具集打包的。这个工具集包含 autoconf 、automake 等工具,所有的这些工具使得维护软件生命周期变得很容易。最终用户不需要了解这些工具,但却可以让软件在不同的 Unix 系统上的安装步骤变得简单。

这一步一般用来生成 Makefile,为下一步的编译做准备,你可以通过在 configure 后加上参数来对安装进行控制,具体参数可以通过 configure --help 察看,下面举几个例子:

1
./configure --prefix=/usr ...
  • --prefix=/usr: 意思是将该软件安装在 /usr 下面,执行文件就会安装在 /usr/bin (而不是默认的 /usr/local/bin), 资源文件就会安装在 /usr/share (而不是默认的 /usr/local/share)。选项的另一个好处是卸载软件或移植软件。当某个安装的软件不再需要时,只须简单的删除该安装目录,就可以把软件卸载得干干净净;移植软件只需拷贝整个目录到另外一个机器即可(相同的操作系统)
  • --bindir=: 指定二进制文件的安装位置。这里的二进制文件定义为可以被用户直接执行的程序
  • --enable-static与--enable-shared:
    • --enable-static: 生成静态链接库
    • --enable-shared: 生成动态链接库
  • --with-: 用于启用或禁用特定功能或模块。例如:
    • --with-ssl 表示启用 SSL 支持
    • --without-gui 表示禁用图形界面。
  • --with-package=dir
  • --with-apxs 是指定 apache 的配置程序路径,php 编译程序会通过这个程序查找 apache 的相关路径
  • --with-libxml-dir: 指向的是 libxml 的库路径
  • --with-gd: 指静态编译 gd 库
  • --with-png-dir: 指定 libpng 的路径
  • --enable-: 用于启用或禁用特定功能或模块。与–with - 选项类似,但更常用于启用或禁用编译选项。
  • --disable-: 用于禁用特定功能或模块。与–enable - 选项相反,用于禁用编译选项。
  • –sys-config=: 指定软件的配置文件。有一些软件还可以加上 –with–enable–without–disable 等等参数对编译加以控制

这一步就是编译,大多数的源代码包都经过这一步进行编译(当然有些 perl 或 python 编写的软件需要调用 perl 或 python 来进行编译)。如果 在 make 过程中出现 error ,你就要记下错误代码(注意不仅仅是最后一行),然后你可以向开发者提交 bugreport(一般在 INSTALL 里有提交地址),或者你的系统少了一些依赖库等,这些需要自己仔细研究错误代码。

可能遇到的错误:make *** 没有指明目标并且找不到 makefile。 没有 Makefile,先./configure 一下,再 makemake uninstall 是卸载,不加参数就是默认的进行源代码编译。

make 工具,它是一个自动化编译工具,你可以使用一条命令实现完全编译。但是你需要编写一个规则文件,make 依据它来批处理编译,这个文件就是 makefile

这条命令来进行安装(当然有些软件需要先运行 make checkmake test 来进行一些测试),这一步一般需要你有 root 权限(因为要向系统写入文件)。

make installmake install prefix=/usr/local/ 等价。

make install prefix=/usr/local/ sysconfdir=/etc DESTDIR=/tmp/build 支持 DESTDIR 的意义就是,保证所有要安装的文件,都会被安装在 DESTDIR 目录下,不会污染系统的 package 的目录。install 也 是 linux 系统命令。

Linux 的用户可能知道,在 Linux 下安装一个应用程序时,一般先运行脚本 configure,然后用 make 来编译源程序,在运行 make install,最后运行 make clean 删除一些临时文件。

configure 是一个 shell 脚本,它可以自动设定源程序以符合各种不同平台上 Unix 系统的特性,并且根据系统叁数及环境产生合适的 Makefile 文件或是 C 的头文件 (header file),让源程序可以很方便地在这些不同的平台上被编译连接。

利用 configure 所产生的 Makefile 文件有几个预设的目标可供使用,其中几个重要的简述如下:

  • make all: 产生我们设定的目标,即此范例中的可执行文件。只打 make 也可以,此时会开始编译原始码,然后连结,并且产生可执行文件。只打 make 默认就是 make all,只编译其中某个目标则在后面给目标名称:make ce-common。
  • make clean: 清除编译产生的可执行文件及目标文件 (object file,*.o)。
  • make distclean: 除了清除可执行文件和目标文件外,把 configure 所产生的 Makefile 也清除掉。
  • make install: 将程序安装至系统中。如果原始码编译无误,且执行结果正确,便可以把程序安装至系统预设的可执行文件存放路径。
  • make dist: 将程序和相关的档案包装成一个压缩文件以供发布。执行完在目录下会产生一个以 PACKAGE-VERSION.tar.gz 为名称的文件。 PACKAGE 和 VERSION 这两个变数是根据 http://configure.in 文件中 AM_INIT_AUTOMAKE (PACKAGE,VERSION) 的定义。在此范例中会产生 test-1.0.tar.gz 的档案。
  • make distcheck: 和 make dist 类似,但是加入检查包装后的压缩文件是否正常。这个目标除了把程序和相关文件包装成 tar.gz 文件外,还会自动把这个压缩文件解开,执行 configure,并且进行 make all 的动作,确认编译无误后,会显示这个 tar.gz 文件可供发布了。这个检查非常有用,检查过关的包,基本上可以给任何一个具备 GNU 开发环境 - 的人去重新编译。

通过源码编译安装一个软件如下:

1
2
3
4
./configure --prefix=/usr/local/${program_name}
make
make install
make clean

注意: --prefix 可以在 configure 或者 make install 时指定安装路径。

Buy me a coffee~
Jian YE 支付宝支付宝
Jian YE 微信微信
0%