Linux中國

RPM 包是如何從源 RPM 製作的

上一篇文章中,我們研究了什麼是 RPM 軟體包。它們是包含文件和元數據的檔案文件。當安裝或卸載 RPM 時,此元數據告訴 RPM 在哪裡創建或刪除文件。正如你將在上一篇文章中記住的,元數據還包含有關「依賴項」的信息,它可以是「運行時」或「構建時」的依賴信息。

例如,讓我們來看看 fpaste。你可以使用 dnf 下載該 RPM。這將下載 Fedora 存儲庫中可用的 fpaste 最新版本。在 Fedora 30 上,當前版本為 0.3.9.2:

$ dnf download fpaste

...
fpaste-0.3.9.2-2.fc30.noarch.rpm

由於這是個構建 RPM,因此它僅包含使用 fpaste 所需的文件:

$ rpm -qpl ./fpaste-0.3.9.2-2.fc30.noarch.rpm
/usr/bin/fpaste
/usr/share/doc/fpaste
/usr/share/doc/fpaste/README.rst
/usr/share/doc/fpaste/TODO
/usr/share/licenses/fpaste
/usr/share/licenses/fpaste/COPYING
/usr/share/man/man1/fpaste.1.gz

源 RPM

在此鏈條中的下一個環節是源 RPM。Fedora 中的所有軟體都必須從其源代碼構建。我們不包括預構建的二進位文件。因此,要製作一個 RPM 文件,RPM(工具)需要:

  • 給出必須要安裝的文件,
  • 例如,如果要編譯出這些文件,則告訴它們如何生成這些文件,
  • 告知必須在何處安裝這些文件,
  • 該特定軟體需要其他哪些依賴才能正常工作。

源 RPM 擁有所有這些信息。源 RPM 與構建 RPM 相似,但顧名思義,它們不包含已構建的二進位文件,而是包含某個軟體的源文件。讓我們下載 fpaste 的源 RPM:

$ dnf download fpaste --source

...
fpaste-0.3.9.2-2.fc30.src.rpm

注意文件的結尾是 src.rpm。所有的 RPM 都是從源 RPM 構建的。你也可以使用 dnf 輕鬆檢查「二進位」 RPM 的源 RPM:

$ dnf repoquery --qf "%{SOURCERPM}" fpaste
fpaste-0.3.9.2-2.fc30.src.rpm

另外,由於這是源 RPM,因此它不包含構建的文件。相反,它包含有關如何從中構建 RPM 的源代碼和指令:

$ rpm -qpl ./fpaste-0.3.9.2-2.fc30.src.rpm
fpaste-0.3.9.2.tar.gz
fpaste.spec

這裡,第一個文件只是 fpaste 的源代碼。第二個是 spec 文件。spec 文件是個配方,可告訴 RPM(工具)如何使用源 RPM 中包含的源代碼創建 RPM(檔案文件)— 它包含 RPM(工具)構建 RPM(檔案文件)所需的所有信息。在 spec 文件中。當我們軟體包維護人員添加軟體到 Fedora 中時,我們大部分時間都花在編寫和完善 spec 文件上。當軟體包需要更新時,我們會回過頭來調整 spec 文件。你可以在 https://src.fedoraproject.org/browse/projects/ 的源代碼存儲庫中查看 Fedora 中所有軟體包的 spec 文件。

請注意,一個源 RPM 可能包含構建多個 RPM 的說明。fpaste 是一款非常簡單的軟體,一個源 RPM 生成一個「二進位」 RPM。而 Python 則更複雜。雖然只有一個源 RPM,但它會生成多個二進位 RPM:

$ sudo dnf repoquery --qf "%{SOURCERPM}" python3
python3-3.7.3-1.fc30.src.rpm
python3-3.7.4-1.fc30.src.rpm

$ sudo dnf repoquery --qf "%{SOURCERPM}" python3-devel
python3-3.7.3-1.fc30.src.rpm
python3-3.7.4-1.fc30.src.rpm

$ sudo dnf repoquery --qf "%{SOURCERPM}" python3-libs
python3-3.7.3-1.fc30.src.rpm
python3-3.7.4-1.fc30.src.rpm

$ sudo dnf repoquery --qf "%{SOURCERPM}" python3-idle
python3-3.7.3-1.fc30.src.rpm
python3-3.7.4-1.fc30.src.rpm

$ sudo dnf repoquery --qf "%{SOURCERPM}" python3-tkinter
python3-3.7.3-1.fc30.src.rpm
python3-3.7.4-1.fc30.src.rpm

用 RPM 行話來講,「python3」 是「主包」,因此該 spec 文件將稱為 python3.spec。所有其他軟體包均為「子軟體包」。你可以下載 python3 的源 RPM,並查看其中的內容。(提示:補丁也是源代碼的一部分):

$ dnf download --source python3
python3-3.7.4-1.fc30.src.rpm

$ rpm -qpl ./python3-3.7.4-1.fc30.src.rpm
00001-rpath.patch
00102-lib64.patch
00111-no-static-lib.patch
00155-avoid-ctypes-thunks.patch
00170-gc-assertions.patch
00178-dont-duplicate-flags-in-sysconfig.patch
00189-use-rpm-wheels.patch
00205-make-libpl-respect-lib64.patch
00251-change-user-install-location.patch
00274-fix-arch-names.patch
00316-mark-bdist_wininst-unsupported.patch
Python-3.7.4.tar.xz
check-pyc-timestamps.py
idle3.appdata.xml
idle3.desktop
python3.spec

從源 RPM 構建 RPM

現在我們有了源 RPM,並且其中有什麼內容,我們可以從中重建 RPM。但是,在執行此操作之前,我們應該設置系統以構建 RPM。首先,我們安裝必需的工具:

$ sudo dnf install fedora-packager

這將安裝 rpmbuild 工具。rpmbuild 需要一個默認布局,以便它知道源 RPM 中每個必需組件的位置。讓我們看看它們是什麼:

# spec 文件將出現在哪裡?
$ rpm -E %{_specdir}
/home/asinha/rpmbuild/SPECS

# 源代碼將出現在哪裡?
$ rpm -E %{_sourcedir}
/home/asinha/rpmbuild/SOURCES

# 臨時構建目錄是哪裡?
$ rpm -E %{_builddir}
/home/asinha/rpmbuild/BUILD

# 構建根目錄是哪裡?
$ rpm -E %{_buildrootdir}
/home/asinha/rpmbuild/BUILDROOT

# 源 RPM 將放在哪裡?
$ rpm -E %{_srcrpmdir}
/home/asinha/rpmbuild/SRPMS

# 構建的 RPM 將放在哪裡?
$ rpm -E %{_rpmdir}
/home/asinha/rpmbuild/RPMS

我已經在系統上設置了所有這些目錄:

$ cd
$ tree -L 1 rpmbuild/
rpmbuild/
├── BUILD
├── BUILDROOT
├── RPMS
├── SOURCES
├── SPECS
└── SRPMS

6 directories, 0 files

RPM 還提供了一個為你全部設置好的工具:

$ rpmdev-setuptree

然後,確保已安裝 fpaste 的所有構建依賴項:

sudo dnf builddep fpaste-0.3.9.2-3.fc30.src.rpm

對於 fpaste,你只需要 Python,並且它肯定已經安裝在你的系統上(dnf 也使用 Python)。還可以給 builddep 命令一個 spec 文件,而不是源 RPM。在手冊頁中了解更多信息:

$ man dnf.plugin.builddep

現在我們有了所需的一切,從源 RPM 構建一個 RPM 就像這樣簡單:

$ rpmbuild --rebuild fpaste-0.3.9.2-3.fc30.src.rpm
..
..

$ tree ~/rpmbuild/RPMS/noarch/
/home/asinha/rpmbuild/RPMS/noarch/
└── fpaste-0.3.9.2-3.fc30.noarch.rpm

0 directories, 1 file

rpmbuild 將安裝源 RPM 並從中構建你的 RPM。現在,你可以使用 dnf 安裝 RPM 以使用它。當然,如前所述,如果你想在 RPM 中進行任何更改,則必須修改 spec 文件,我們將在下一篇文章中介紹 spec 文件。

總結

總結一下這篇文章有兩點:

  • 我們通常安裝使用的 RPM 是包含軟體的構建版本的 「二進位」 RPM
  • 構建 RPM 來自於源 RPM,源 RPM 包括用於生成二進位 RPM 所需的源代碼和規範文件。

如果你想開始構建 RPM,並幫助 Fedora 社區維護我們提供的大量軟體,則可以從這裡開始: https://fedoraproject.org/wiki/Join_the_package_collection_maintainers

如有任何疑問,請發郵件到 Fedora 開發人員郵件列表,我們隨時樂意為你提供幫助!

via: https://fedoramagazine.org/how-rpm-packages-are-made-the-source-rpm/

作者:Ankur Sinha FranciscoD 選題:lujun9972 譯者:wxy 校對:wxy

本文由 LCTT 原創編譯,Linux中國 榮譽推出


本文轉載來自 Linux 中國: https://github.com/Linux-CN/archive

對這篇文章感覺如何?

太棒了
0
不錯
0
愛死了
0
不太好
0
感覺很糟
0
雨落清風。心向陽

    You may also like

    Leave a reply

    您的郵箱地址不會被公開。 必填項已用 * 標註

    此站點使用Akismet來減少垃圾評論。了解我們如何處理您的評論數據

    More in:Linux中國