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
訂閱“Linux 中國”官方小程式來檢視
相關文章
- Linux自己製作rpm包Linux
- 製作PHP的RPM包例項PHP
- 使用CheckInstall從原始碼製作RPM安裝包原始碼
- Centos 7 製作MySQL 5.7 RPM包CentOSMySql
- 如何製作一個 RPM 檔案
- 如何構建 RPM 包
- Linux之RPM包管理_RPM包查詢Linux
- rpm包的查詢
- RPM包的構建
- POSTGRESQL10.3 RPM包 主從搭建SQL
- RPM 包初窺
- Linux rpm查詢命令以及RPM包驗證Linux
- yum如何解除安裝已安裝的rpm並安裝本地rpm包
- centos(linux): rpm -V 驗證rpm包安裝程式的安全CentOSLinux
- 構建自己的postgresql rpm包SQL
- RPM是什麼
- 原始碼包和rpm包的區別原始碼
- OpenSSH9.6p1的EL7版本rpm安裝包製作
- RPM索引在Artifactory中是如何工作索引
- RPM包的安裝與升級
- rpm:虛擬包:空白包:欺騙包:do nothing包:滿足現有rpm包安裝依賴的要求
- RPM包安裝與介紹
- 對RPM軟體包的查詢操作
- mysql8.0.30的RPM包安裝方法MySql
- 搭建本地yum源,使用安裝光碟的rpm作為yum源的檔案
- Linux rpm -e --nodeps rpm解除安裝Linux
- CentOS下使用rpm包安裝MySQLCentOSMySql
- Linux軟體管理之RPM包1Linux
- rpm包的校驗和檔案讀取
- centos以RPM包方式安裝redis的方法CentOSRedis
- 在 Fedora 中安裝替代版本的 RPM 包
- RPM 的 spec 檔案如何編寫
- 如何編寫 RPM 的 spec 檔案
- Linux - openssh透過原始碼build rpm包Linux原始碼UI
- 雲端計算學習路線教程大綱課件:使用RPM工具管理RPM包
- 基於Linux的MySQL5.7RPM包安裝LinuxMySql
- RPM打包之路
- yum/dnf/rpm 等 檢視rpm 包安裝路徑 (fedora 中 pygtk 包內容安裝到哪裡了)