探讨 ebuild 系统

Daniel Robbins
总裁兼 CEO, Gentoo Technologies, Inc.
2000 年 5 月

Daniel Robbins 在其最后一篇 Bash实例文章中周详讲述了 Gentoo Linux ebuild 系统,这个展示 bash能力的极佳范例。循序渐进地,他为您展示如何实现 ebuild系统,并触及很多方便的 bash技术和设计策略。在本文末尾,您将很好地掌控制造完全基于 bash的应用所涉及的技术,并开始为自己的自动构建系统编码。

进入 ebuild 系统
我真是一直期待着这第三篇、也是最后一篇 Bash 实例文章,因为既然已在 第 1 篇和 第 2 篇 中讲述了 bash 编程基础,就能够集中讲述象 bash 应用研发和程式设计这样更高级的主题。在本文中,将通过我花了许多时间来编码和细化的项目,Gentoo Linux ebuild 系统,来给您大量实际的、现实世界的 bash 研发经验。

我是 Gentoo Linux(现在还是 beta 版的下一代 Linux OS)的首席设计师。我的主要责任之一就是确保任何二进制包(类似于 RPM)都正确创建并一起使用。正如您可能知道的,标准 Linux 系统不是由一棵统一的源树组成(象 BSD),而实际上是由超过 25 个协同工作的核心包组成。这其中包括:

描述
linux实际内核
util-linux和 Linux 相关的杂项程式集合
e2fsprogs和 ext2 文档系统相关的实用程式集合
glibcGNU C 库

每个包都位于各自的 tar 压缩包中,并由不同的单独研发人员或研发小组维护。要创建一个发行版,必须对每个包分别进行下载、编译和打包处理。每次要修复、升级或改进包时,都必须重复编译和打包步骤(并且,包确实更新得很快)。为了帮助消除创建和更新包所涉及的重复步骤,我创建了 ebuild 系统,该系统几乎全用 bash 编写。为了增加您的 bash 知识,我将循序渐进地为您演示如何实现该 ebuild 系统的解包和编译部分。在解释每一步时,还将讨论为什么要作出某些设计决定。在本文末尾,您不但将极好地掌控大型 bash 编程项目,还实现了完整自动构建系统的很大一部分。

为什么选择 bash?
Bash 是 Gentoo Linux ebuild 系统的基本组件。选择他做为 ebuild 的主要语言有几个原因。首先,其语法不复杂,并且为人们所熟悉,这特别适合于调用外部程式。自动构建系统是自动调用外部程式的“胶合代码”,而 bash 很适合于这种类型的应用。第二,Bash 对函数的支持允许 ebuild 系统使用模块化、易于理解的代码。第三,ebuild 系统利用了 bash 对环境变量的支持,允许包维护人员和研发人员在运行时对其进行方便的在线配置。

构建过程回顾
在讨论 ebuild 系统之前,让我们回顾一下编译和安装包都牵涉些什么。例如,让我们看一下 "sed" 包,这个作为任何 Linux 版本一部分的标准 GNU 文本流编辑实用程式。首先,下载源代码 tar 压缩包 (sed-3.02.tar.gz)(请参阅 参考资料 )。我们将把这个档案存储在 /usr/src/distfiles 中,将使用环境变量 "$DISTDIR" 来引用该目录。"$DISTDIR" 是任何原始源代码 tar 压缩包所在的目录,他是个大型源代码库。

下一步是创建名为 "work" 的临时目录,该目录存放已解压的源代码。以后将使用 "$WORKDIR" 环境变量引用该目录。要做到这点,进入有写权限的目录,然后输入:

将 sed 解压缩到临时目录


$ mkdir work

$ cd work

$ tar xzf /usr/src/distfiles/sed-3.02.tar.gz

然后,解压缩 tar 压缩包,创建一个包含任何源代码、名为 sed-3.02 的目录。以后将使用环境变量 "$SRCDIR" 引用 sed-3.02 目录。要编译程式,输入:

将 sed 解压缩到临时目录


$ cd sed-3.02

$ ./configure --prefix=/usr

(autoconf 生成适当的 make 文档,这要花一些时间)



$ make



(从源代码编译包,也要花一点时间)



因为在本文中只讲述解包和编译步骤,所以将略过 "make install" 步骤。假如要编写 bash 脚本来执行任何这些步骤,则代码可能类似于:

要执行解包/编译过程的样本 bash 脚本


#!/usr/bin/env bash



if [ -d work ]

then 

# remove old work directory if it exists 

    rm -rf work

fi

mkdir work

cd work

tar xzf /usr/src/distfiles/sed-3.02.tar.gz

cd sed-3.02

./configure --prefix=/usr

make

使代码通用
虽然能够使用这个自动编译脚本,但他不是很灵活。基本上,bash 脚本只包含在命令行输入的任何命令列表。虽然能够使用这种解决方案,但是,最好做一个只通过更改几行就能够快速解包和编译任何包的适用脚本。这样,包维护人员将新包添加到发行版所需的工作就大为减少。让我们先尝试一下使用许多不同的环境变量来完成,使构建脚本更加适用:

文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!