在上一篇文章中,咱們研究了什麼是 RPM 軟件包。它們是包含文件和元數據的檔案文件。當安裝或卸載 RPM 時,此元數據告訴 RPM 在哪裏建立或刪除文件。正如你將在上一篇文章中記住的,元數據還包含有關「依賴項」的信息,它能夠是「運行時」或「構建時」的依賴信息。html
例如,讓咱們來看看 fpaste
。你可使用 dnf
下載該 RPM。這將下載 Fedora 存儲庫中可用的 fpaste
最新版本。在 Fedora 30 上,當前版本爲 0.3.9.2:python
$ dnf download fpaste
...
fpaste-0.3.9.2-2.fc30.noarch.rpm
複製代碼
因爲這是個構建 RPM,所以它僅包含使用 fpaste
所需的文件:linux
$ 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。Fedora 中的全部軟件都必須從其源代碼構建。咱們不包括預構建的二進制文件。所以,要製做一個 RPM 文件,RPM(工具)須要:git
源 RPM 擁有全部這些信息。源 RPM 與構建 RPM 類似,但顧名思義,它們不包含已構建的二進制文件,而是包含某個軟件的源文件。讓咱們下載 fpaste
的源 RPM:github
$ dnf download fpaste --source
...
fpaste-0.3.9.2-2.fc30.src.rpm
複製代碼
注意文件的結尾是 src.rpm
。全部的 RPM 都是從源 RPM 構建的。你也可使用 dnf
輕鬆檢查「二進制」 RPM 的源 RPM:bash
$ dnf repoquery --qf "%{SOURCERPM}" fpaste
fpaste-0.3.9.2-2.fc30.src.rpm
複製代碼
另外,因爲這是源 RPM,所以它不包含構建的文件。相反,它包含有關如何從中構建 RPM 的源代碼和指令:app
$ 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 文件。你能夠在 src.fedoraproject.org/browse/proj… 的源代碼存儲庫中查看 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,並查看其中的內容。(提示:補丁也是源代碼的一部分):ui
$ 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。首先,咱們安裝必需的工具:
$ 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,並幫助 Fedora 社區維護咱們提供的大量軟件,則能夠從這裏開始: fedoraproject.org/wiki/Join_t…
若有任何疑問,請發郵件到 Fedora 開發人員郵件列表,咱們隨時樂意爲你提供幫助!
via: fedoramagazine.org/how-rpm-pac…
做者:Ankur Sinha "FranciscoD" 選題:lujun9972 譯者:wxy 校對:wxy