PRF:20171107 How I created my first RPM package in Fedora.md

@qhwdw
This commit is contained in:
wxy 2017-11-14 19:23:12 +08:00
parent 4cda36d29d
commit 0276cb7a77

View File

@ -1,17 +1,18 @@
# 怎么在 Fedora 中创建我的第一个 RPM 包?
怎么在 Fedora 中创建我的第一个 RPM 包?
==============
![](https://i0.wp.com/blog.justinwflory.com/wp-content/uploads/2017/11/newpackage.png?resize=1024%2C433&ssl=1)
过了这个夏天,我迁移我的桌面环境到 i3一个 Tiling 窗口管理器。当初,切换到 i3 是一个挑战,因为我必须去处理许多以前 GNOME 帮我处理的事情。其中一件事情就是改变屏幕亮度。 xbacklight在笔记本电脑上改变背光亮度的标准方法,它在我的硬件上不工作了。
过了这个夏天,我把我的桌面环境迁移到了 i3这是一个瓦片式窗口管理器。当初,切换到 i3 是一个挑战,因为我必须去处理许多以前 GNOME 帮我处理的事情。其中一件事情就是改变屏幕亮度。 xbacklight 这个在笔记本电脑上改变背光亮度的标准方法,它在我的硬件上不工作了。
最近,我发现[brightlight][1],一个改变背光亮度的工具。我决定去试一下它,它工作在 root 权限下。但是,我发现 brightligh 在 Fedora 下没有 RPM 包。我决定,是在 Fedora 下尝试创建一个包的时候了,并且可以学习怎么去创建一个 RPM 包。
最近,我发现一个改变背光亮度的工具 [brightlight][1]。我决定去试一下它,它工作在 root 权限下。但是,我发现 brightligh 在 Fedora 下没有 RPM 包。我决定,是在 Fedora 下尝试创建一个包的时候了,并且可以学习怎么去创建一个 RPM 包。
在这篇文章中,我将分享以下的内容:
*创建 RPM SPEC 文件
*在 Koji 和 Copr 中构建包
*使用 debug 包处理一个问题
*提交这个包到 Fedora 包集中
* 创建 RPM SPEC 文件
* 在 Koji 和 Copr 中构建包
* 使用调试包处理一个问题
* 提交这个包到 Fedora 包集
### 前提条件
@ -25,15 +26,15 @@ sudo dnf install fedora-packager fedpkg fedrepo_req copr-cli
创建 RPM 包的第一步是去创建 SPEC 文件。这些规范,或者是指令,它告诉 RPM 怎么去构建包。这是告诉 RPM 从包的源代码中创建一个二进制文件。创建 SPEC 文件看上去是整个包处理过程中最难的一部分,并且它的难度取决于项目。
对我而言幸运的是brightlight 是一个用 C 写的简单应用程序。维护人员可以很容易地创建一个 Makefile 的二进制应用程序。构建它只是在库中简单运行 make 的问题。因此,我用一个简单的项目去学习 RPM 打包。
对我而言幸运的是brightlight 是一个用 C 写的简单应用程序。维护人员用一个 Makefile 使创建二进制应用程序变得很容易。构建它只是在仓库中简单运行 `make` 的问题。因此,我现在可以用一个简单的项目去学习 RPM 打包。
### 查找文档
#### 查找文档
谷歌搜索 “how to create an RPM package” 有很多结果。我开始使用的是 [IBM 的文档][2]。然而,我发现它理解起来非常困难,不知所云(虽然十分详细,它可能适用于复杂的 app。我也在 Fedora 维基上找到了 [创建包][3] 的介绍。这个文档在构建和处理上解释的非常好,但是,我一直困惑于 “怎么去开始呢?”
最终,我找到了 [RPM 打包准则][4],它是大神 [Adam Miller][5] 写的。这些介绍非常有帮助,并且包含了三个优秀的示例,它们分别是用 Bash、C 和 Python 写的。这个指南帮我很容易地理解了怎么去构建一个 RPM SPEC并且更重要的是解释了怎么把这些片断拼到一起。
最终,我找到了 [RPM 打包指南][4],它是大神 [Adam Miller][5] 写的。这些介绍非常有帮助,并且包含了三个优秀的示例,它们分别是用 Bash、C 和 Python 写的程序。这个指南帮我很容易地理解了怎么去构建一个 RPM SPEC并且更重要的是解释了怎么把这些片断拼到一起。
有了这些之后,我可以去写 brightlight 程序的我的 [第一个 SPEC 文件][6] 了。因为它是很简单的SPEC 很短也很容易理解。因此,我有了我的 SPEC 文件,我发现其中一些错误。处理掉一些错误之后,我创建了源 RPM (SRPM) 和二进制 RPM然后我解决了出现的问题。
有了这些之后,我可以去写 brightlight 程序的我的 [第一个 SPEC 文件][6] 了。因为它是很简单的SPEC 很短也很容易理解。我有了 SPEC 文件之后,我发现其中一些错误。处理掉一些错误之后,我创建了源 RPM (SRPM) 和二进制 RPM然后我解决了出现的每个问题。
```
rpmlint SPECS/brightlight.spec
@ -43,27 +44,27 @@ rpmbuild -bb SPECS/brightlight-5-1.fc26.x86_64.rpm
rpmlint RPMS/x86_64/brightlight-5-1.fc26.x86_64.rpm
```
现在,我有了一个可用的 RPM可以发送到 Fedora 库了。
现在,我有了一个可用的 RPM可以发送到 Fedora 库了。
### 在 Copr 和 Koji 中构建
接下来,我读了 [指南][7] 中关于怎么去为 Fedora 创建一个包。在提交之前,他们鼓励打包者通过在一个构建在 [Koji][9] 中托管的 [Copr][8] 库项目去测试要提交的包。
接下来,我读了该 [指南][7] 中关于怎么成为一个 Fedora 打包者。在提交之前,他们鼓励打包者通过在在 [Koji][9] 中托管、并在 [Copr][8] 中构建项目来测试要提交的包。
#### 使用 Copr
首先,我为 brightlight 创建了一个 [Copr 库][10][Copr][11] 是在 Fedora 的基础设施中的一个服务,它构建你的包,并且设置一个你选择的 Fedora 或 EPEL 的任意版本。它快速运行你的 RPM 包,并与其它人去分享是非常方便的。使用一个 Copr 的主机你不需要特定的许可
首先,我为 brightlight 创建了一个 [Copr 库][10][Copr][11] 是在 Fedora 的基础设施中的一个服务,它构建你的包,并且为你任意选择的 Fedora 或 EPEL 版本创建一个定制仓库。它对于快速托管你的 RPM 包,并与其它人去分享是非常方便的。你不需要特别操心如何去托管一个 Copr 仓库
我从 web 接口创建了我的 Copr 项目,但是,你也可以使用 copr-cli 工具。这儿是一个 Fedora 开发者入门的 [非常优秀的指南][12]。在网站上创建了我的库之后,我使用这个命令构建了我的包。
我从 Web 界面创建了我的 Copr 项目,但是,你也可以使用 `copr-cli` 工具。在 Fedora 开发者网站上有一个 [非常优秀的指南][12]。在该网站上创建了我的仓库之后,我使用这个命令构建了我的包。
```
copr-cli build brightlight SRPMS/brightlight.5-1.fc26.src.rpm
```
我的包成功构建,并且,我可以很容易地在我的 Fedora 系统上成功安装它。
我的包在 Corp 上成功构建,并且,我可以很容易地在我的 Fedora 系统上成功安装它。
#### 使用 Koji
任何人都可以使用 [Koji][13] 在多种架构和 Fedora 或 CentOS/RHEL 版本中,去测试他们的包。在 Koji 中测试,你必须有一个源 RPM。我希望 brightlight 包在 Fedora 所有的版本中都支持,因此,我运行如下的命令:
任何人都可以使用 [Koji][13] 在多种架构和 Fedora 或 CentOS/RHEL 版本测试他们的包。在 Koji 中测试,你必须有一个源 RPM。我希望 brightlight 包在 Fedora 所有的版本中都支持,因此,我运行如下的命令:
```
koji build --scratch f25 SRPMS/brightlight-5-1.fc26.src.rpm
@ -71,18 +72,18 @@ koji build --scratch f26 SRPMS/brightlight-5-1.fc26.src.rpm
koji build --scratch f27 SRPMS/brightlight-5-1.fc26.src.rpm
```
它花费了一些时间但是Koji 构建了所有的包。我的包可以很完美地运行在 Fedora 25 和 26 中,但是 Fedora 27 失败了。 Koji 模拟构建始终保持一个跟踪,并且确保我的包构建成功。
它花费了一些时间但是Koji 构建了所有的包。我的包可以很完美地运行在 Fedora 25 和 26 中,但是 Fedora 27 失败了。 Koji 模拟构建可以使我走在正确的路线上,并且确保我的包构建成功。
### 问题Fedora 27 构建失败!
现在,我已经知道我的 Fedora 27 上的包在 Koji 上构建失败了。但是,为什么呢?我发现在 Fedora 27 上有两个相关的变化。
*[Subpackage and Source Debuginfo][14]
*[RPM 4.14][15] (特别是debuginfo 包重写了)
* [Subpackage and Source Debuginfo][14]
* [RPM 4.14][15] (特别是debuginfo 包重写了)
这些变化意味着 RPM 包必须使用一个 debuginfo 包去构建。这有助于排错或调试一个应用程序。在我的案例中,这并不是关键的或者很必要的,但是,我需要去构建一个。
感谢 Igor Gnatenko他帮我理解了为什么我在 Fedora 27 上构建包需要去将这些增加到我的包的 SPEC 中。在 %make_build 宏指令之前,我增加了这些行。
感谢 Igor Gnatenko他帮我理解了为什么我在 Fedora 27 上构建包需要去将这些增加到我的包的 SPEC 中。在 `%make_build` 宏指令之前,我增加了这些行。
```
export CFLAGS="%{optflags}"
@ -93,13 +94,13 @@ export LDFLAGS="%{__global_ldflags}"
### 提交这个包
现在,我在 Fedora 25 到 27 上成功校验了我的包,是时候为 Fedora 打包了。第一步是提交这个包,在 Red Hat Bugzilla 上为了评估包,去创建一个新 bug。我为 brightlight [创建了一个票据][16]。因为这是我的第一个包,我显式的标注它 “这是我的第一个包”,并且我寻找一个赞助商。在票据中,我链接 SPEC 和 SRPM 文件到我的 Git 库中。
现在,我在 Fedora 25 到 27 上成功校验了我的包,是时候为 Fedora 打包了。第一步是提交这个包,为了请求一个包评估,要在 Red Hat Bugzilla 创建一个新 bug。我为 brightlight [创建了一个工单][16]。因为这是我的第一个包,我明确标注它 “这是我的第一个包”,并且我寻找一个发起人。在工单中,我链接 SPEC 和 SRPM 文件到我的 Git 库中。
#### 进入 dist-git
[Igor Gnatenko][17] 发起我进入 Fedora 包组,并且在我的包上留下反馈。我学习了一些其它的关于 C 应用程序打包的特定的知识。在他响应我之后,我可以在 [dist-git][18] 上请一个库Fedora 的 RPM 包集库为所有的 Fedora 保存了 SPEC 文件。
[Igor Gnatenko][17] 发起我进入 Fedora 者群组,并且在我的包上留下反馈。我学习了一些其它的关于 C 应用程序打包的特定的知识。在他响应我之后,我可以在 [dist-git][18] 上请一个Fedora 的 RPM 包集合仓库为所有的 Fedora 版本保存了 SPEC 文件。
一个很方便的 Python 工具可以帮你很容易地去生成这部分内容。fedrepo-req 是一个用于创建一个新的 dist-git 库的请求的工具。我用这个命令提交我的请求。
一个很方便的 Python 工具使得这一部分很容易。`fedrepo-req` 是一个用于创建一个新的 dist-git 仓库的请求的工具。我用这个命令提交我的请求。
```
fedrepo-req brightlight \
@ -108,26 +109,27 @@ fedrepo-req brightlight \
--upstreamurl https://github.com/multiplexd/brightlight
```
它为我在 fedora-scm-requests 库创建了一个新的票据。一个我是管理员的 [创建的库][19]。现在,我可以做生意了!
它为我在 fedora-scm-requests 仓库创建了一个新的工单。这是一个我是管理员的 [创建的仓库][19]。现在,我可以开始干了!
![](https://i0.wp.com/blog.justinwflory.com/wp-content/uploads/2017/11/Screenshot-from-2017-11-05-19-58-47.png?w=1366&ssl=1)
My first RPM in Fedora dist-git woohoo!
*My first RPM in Fedora dist-git woohoo!*
#### 与 dist-git 一起工作
接下来fedpkg 是用于和 dist-git 库进行交互的工具。我改变当前目录到我的 git 工作目录,然后运行这个命令。
接下来,`fedpkg` 是用于和 dist-git 库进行交互的工具。我改变当前目录到我的 git 工作目录,然后运行这个命令。
```
fedpkg clone brightlight
```
fedpkg 从 dist-git 克隆了我的包的库。对于这个仅有的第一个分支,你需要去导入 SRPM。
`fedpkg` 从 dist-git 克隆了我的包的库。对于这个仅有的第一个分支,你需要去导入 SRPM。
```
fedpkg import SRPMS/brightlight-5-1.fc26.src.rpm
```
fedpkg 导入你的包的 SRPM 到这个库中,然后设置源为你的 Git 库。使用 fedpkg 这一步是很重要的,因为它用一个 Fedora 友好的方去帮助规范这个库(与手动添加文件相比)。一旦你导入了 SRPM推送这个改变到 dist-git 库。
`fedpkg` 导入你的包的 SRPM 到这个库中,然后设置源为你的 Git 库。这一步对于使用 `fedpkg` 是很重要的,因为它用一个 Fedora 友好的方去帮助规范这个库(与手动添加文件相比)。一旦你导入了 SRPM推送这个改变到 dist-git 库。
```
git commit -m "Initial import (#1505026)."
@ -136,13 +138,13 @@ git push
#### 构建包
自从你推送第一个包导入到你的 dist-git 库中,你已经准备好去做一个真正的 Koji 项目构建者。去构建你的项目,运行这个命令。
自从你推送第一个包导入到你的 dist-git 仓库中,你已经准备好了为你的项目做一次真实的 Koji 构建。要构建你的项目,运行这个命令。
```
fedpkg build
```
它在 Koji 中为 Rawhide 构建你的包,这是 Fedora 中的非受控分支。在你为其它分支构建之前,你必须在 Rawhide 分支上构建成功。如果构建成功,你现在可以为你的项目的其它分支发送请求了。
在 Koji 中为 Rawhide 构建你的包,这是 Fedora 中的非版本控制的分支。在你为其它分支构建之前,你必须在 Rawhide 分支上构建成功。如果一切构建成功,你现在可以为你的项目的其它分支发送请求了。
```
fedrepo-req brightlight f27 -t 1505026
@ -152,7 +154,7 @@ fedrepo-req brightlight f25 -t 1505026
#### 关于构建其它分支的注意事项
一旦你初始导入了 SRPM如果你选择去创建它们记得合并你的主分支到其它分支。例如,如果你后面为 Fedora 27 请求一个分支,你将需要去使用这些命令。
一旦你最初导入了 SRPM如果你选择去创建其它分支记得合并你的主分支到它们。例如,如果你后面为 Fedora 27 请求一个分支,你将需要去使用这些命令。
```
fedpkg switch-branch f27
@ -163,33 +165,33 @@ fedpkg build
#### 提交更新到 Bodhi
这个过程的最后一步是,提交你的新包作为一个更新到 Bodhi 中。当你初次提交你的更新包时,它将去测试这个库。任何人都可以测试你的包并且增加 karma 到更新中。如果你的更新接收了 3 个以上的投票(或者像 Bodhi 称它为 karma你的包将自动被推送到稳定库。否则,一周之后,在测试库中推送它
这个过程的最后一步是,把你的新包作为一个更新包提交到 Bodhi 中。当你初次提交你的更新包时,它将去测试这个库。任何人都可以测试你的包并且增加 karma 到更新中。如果你的更新接收了 3 个以上的投票(或者像 Bodhi 称它为 karma你的包将自动被推送到稳定仓库。否则,一周之后,推送到测试仓库中
提交你的更新到 Bodhi你仅需要一个命令。
提交你的更新到 Bodhi你仅需要一个命令。
```
fedpkg update
```
它为你的包用一个不同的配置选项打开一个 Vim 窗口。一般情况下,你仅需要去指定一个输入(比如,新包),然后,去检查你的包的票据 ID 数字。对于更深入的讲解,这里有一个 Fedora 维基上的更新指南
它为你的包用一个不同的配置选项打开一个 Vim 窗口。一般情况下,你仅需要去指定一个 类型(比如,`newpackage`)和一个你的包评估的票据 ID。对于更深入的讲解在 Fedora 维基上有一篇[更新的指南][23]
在保存和退出这个文件后,fedpkg 提交你的包作为一个更新到 Bodhi最后同步到 Fedora 测试库。我也可以用这个命令去安装我的包。
在保存和退出这个文件后,`fedpkg` 会把你的包以一个更新包提交到 Bodhi最后同步到 Fedora 测试仓库。我也可以用这个命令去安装我的包。
```
sudo dnf install brightlight -y --enablerepo=updates-testing --refresh
```
### 我们是稳定的
### 稳定仓库
最近提交了我的包到 [Fedora 26 稳定库][20],并且不久将进入 [Fedora 25][21] 和 [Fedora 27][22] 稳定库。感谢帮助我完成我的第一个包的每个人。我期待有更多的机会为发行版添加包。
最近提交了我的包到 [Fedora 26 稳定库][20],并且不久将进入 [Fedora 25][21] 和 [Fedora 27][22] 稳定库。感谢帮助我完成我的第一个包的每个人。我期待有更多的机会为发行版添加包。
--------------------------------------------------------------------------------
via: https://blog.justinwflory.com/2017/11/first-rpm-package-fedora/
作者:[JUSTIN W. FLORY ][a]
作者:[JUSTIN W. FLORY][a]
译者:[qhwdw](https://github.com/qhwdw)
校对:[校对者ID](https://github.com/校对者ID)
校对:[wxy](https://github.com/wxy)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
@ -215,4 +217,5 @@ via: https://blog.justinwflory.com/2017/11/first-rpm-package-fedora/
[19]:https://src.fedoraproject.org/rpms/brightlight
[20]:https://bodhi.fedoraproject.org/updates/brightlight-5-1.fc26
[21]:https://bodhi.fedoraproject.org/updates/FEDORA-2017-8071ee299f
[22]:https://bodhi.fedoraproject.org/updates/FEDORA-2017-f3f085b86e
[22]:https://bodhi.fedoraproject.org/updates/FEDORA-2017-f3f085b86e
[23]: https://fedoraproject.org/wiki/Package_update_HOWTO