这篇文章给大家介绍RPM 的 spec文件如何编写,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
了解源代码
在开始编写 spec 文件之前,你需要对要打包的软件有所了解。在这里,你正在研究 fpaste,这是一个非常简单的软件。它是用 Python 编写的,并且是一个单文件
脚本。当它发布新版本时,可在 Pagure 上找到:https://pagure.io/releases/fpaste/fpaste-0.3.9.2.tar.gz。如该档案文件所示,当前版本为 0.3.9.2。下载它,以便你查看该档案文件中的内容:你要安装的文件是:fpaste.py:应该安装到 /usr/bin/。
docs/man/en/fpaste.1:手册,应放到 /usr/share/man/man1/。
COPYING:许可证文本,应放到 /usr/share/license/fpaste/。
README.rst、TODO:放到 /usr/share/doc/fpaste/ 下的其它文档。这些文件的安装位置取决于文件系统层次结构标准(FHS)。要了解更多信息,可以在这里阅读:http://www.pathname.com/fhs/ 或查看 Fedora 系统的手册页:
第一部分:要构建什么?
现在我们知道了源文件中有哪些文件,以及它们要存放的位置,让我们看一下 spec 文件。你可以在此处查看这个完整的文件:https://src.fedoraproject.org/rpms/fpaste/blob/master/f/fpaste.spec。这是 spec 文件的第一部分:Name、Version 等称为标签,它们定义在 RPM 中。这意味着你不能只是随意写点标签,RPM 无法理解它们!需要注意的标签是:Source0:告诉 RPM 该软件的源代码档案文件所在的位置。
Requires:列出软件的运行时依赖项。RPM 可以自动检测很多依赖项,但是开发云主机域名在某些情况下,必须手动指明它们。运行时依赖项是系统上必须具有的功能(通常是软件包),才能使该软件包起作用。这是 dnf 在安装此软件包时检测是否需要拉取其他软件包的方式。
BuildRequires:列出了此软件的构建时依赖项。这些通常必须手动确定并添加到 spec 文件中。
BuildArch:此软件为该计算机体系结构所构建。如果省略此标签,则将为所有受支持的体系结构构建该软件。值 noarch 表示该软件与体系结构无关(例如 fpaste,它完全是用 Python 编写的)。本节提供有关 fpaste 的常规信息:它是什么,正在将什么版本制作为 RPM,其许可证等等。如果你已安装 fpaste,并查看其元数据时,则可以看到该 RPM 中包含的以下信息:RPM 会自动添加一些其他标签,以代表它所知道的内容。至此,我们掌握了要为其构建 RPM 的软件的一般信息。接下来,我们开始告诉 RPM 做什么。
第二部分:准备构建
spec 文件的下一部分是准备部分,用 %prep 代表:对于 fpaste,这里唯一的
命令是 %autosetup。这只是将 tar 档案文件提取到一个新文件夹中,并为下一部分的构建阶段做好了准备。你可以在此处执行更多操作,例如应用补丁程序,出于不同目的修改文件等等。如果你查看过 Python 的源 RPM 的内容,那么你会在那里看到许多补丁。这些都将在本节中应用。通常,spec 文件中带有 % 前缀的所有内容都是 RPM 以特殊方式解释的宏或标签。这些通常会带有大括号,例如 %{example}。
第三部分:构建软件
下一部分是构建软件的位置,用 %build 表示。现在,由于 fpaste 是一个简单的纯 Python
脚本,因此无需构建。因此,这里是:不过,通常来说,你会在此处使用构建
命令,例如:构建部分通常是 spec 文件中最难的部分,因为这是从源代码构建软件的地方。这要求你知道该工具使用的是哪个构建系统,该系统可能是许多构建系统之一:Autotools、CMake、Meson、Setuptools(用于 Python)等等。每个都有自己的命令开发云主机域名和语法样式。你需要充分了解这些才能正确构建软件。
第四部分:安装文件
软件构建后,需要在 %install 部分中安装它:在构建 RPM 时,RPM 不会修改你的系统文件。在一个可以正常运行的系统上添加、删除或修改文开发云主机域名件的风险太大。如果发生故障怎么办?因此,RPM 会创建一个专门打造的文件系统并在其中工作。这称为 buildroot。 因此,在 buildroot 中,我们创建由宏 %{_bindir} 代表的 /usr/bin 目录,然后使用提供的 Makefile 将文件安装到其中。至此,我们已经在专门打造的 buildroot 中安装了 fpaste 的构建版本。
第五部分:列出所有要包括在 RPM 中的文件
spec 文件其后的一部分是文件部分:%files。在这里,我们告诉 RPM 从该 spec 文件创建的档案文件中包含哪些文件。fpaste 的文件部分非常简单:请注意,在这里,我们没有指定 buildroot。所有这些路径都是相对路径。%doc 和 %license命令做的稍微多一点,它们会创建所需的文件夹,并记住这些文件必须放在那里。RPM 很聪明。例如,如果你在 %install 部分中安装了文件,但未列出它们,它会提醒你。
第六部分:在变更日志中记录所有变更
Fedora 是一个基于社活动:慈云数据爆款香港服务器,CTG+CN2高速带宽、快速稳定、平均延迟10+ms 速度快,免备案,每月仅需19元!! 点击查看区的项目。许多贡献者维护或共同维护软件包。因此,当务之急是不要被软件包做了哪些更改所搞混。为了确保这一点,spec 文件包含的最后一部分是变更日志 %changelog:spec 文件的每项变更都必须有一个变更日志条目。如你在此处看到的,虽然我以维护者身份更新了该 spec 文件,但其他人也做过更改。清楚地记录变更内容有助于所有人知道该 spec 文件的当前状态。对于系统上安装的所有软件包,都可以使用 rpm 来查看其更改日志:
构建 RPM
现在我们准备构建 RPM 包。如果要继续执行以下命令,请确保遵循上一篇文章中的步骤设置系统以构建 RPM。我们将 fpaste 的 spec 文件放置在 ~/rpmbuild/SPECS 中,将源代码档案文件存储在 ~/rpmbuild/SOURCES/ 中,现在可以创建源 RPM 了:让我们看一下结果:我们看到源 RPM 已构建。让我们同时构建源 RPM 和二进制 RPM:RPM 将向你显示完整的构建输出,并在我们之前看到的每个部分中详细说明它的工作。此“构建日志”非常重要。当构建未按预期进行时,我们的打包人员将花费大量时间来遍历它们,以跟踪完整的构建路径来查看出了什么问题。就是这样!准备安装的 RPM 应该位于以下位置:$ ls ~/rpmbuild/RPMS/noarch/
fpaste-0.3.9.2-3.fc30.noarch.rpm
概括
我们已经介绍了如何从 spec 文件构建 RPM 的基础知识。这绝不是一份详尽的文档。实际上,它根本不是文档。它只是试图解释幕后的运作方式。简短回顾一下:RPM 有两种类型:源 RPM 和 二进制 RPM。
二进制 RPM 包含要安装以使用该软件的文件。
源 RPM 包含构建二进制 RPM 所需的信息:完整的源代码,以及 spec 文件中的有关如何构建 RPM 的说明。
spec 文件包含多个部分,每个部分都有其自己的用途。 在这里,我们已经在安装好的 Fedora 系统中本地构建了 RPM。虽然这是个基本的过程,但我们从存储库中获得的 RPM 是建立在具有严格配置和方法的专用服务器上的,以确保正确性和安全性。这个 Fedora 打包流程将在以后的文章中讨论。你想开始构建软件包,并帮助 Fedora 社区维护我们提供的大量软件吗?你可以从这里开始加入软件包集合维护者。关于RPM 的 spec文件如何编写就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
本文从转载,原作者保留一切权利,若侵权请联系删除。
《RPM 的 spec文件如何编写》来自互联网同行内容,若有侵权,请联系我们删除!
还没有评论,来说两句吧...