跳至主要内容
版本:1.23.6

RPM 套件註冊表

為您的用戶或組織發布 RPM 套件。

需求

要使用 RPM 註冊表,您需要使用像 yumdnfzypper 這樣的套件管理器來消費套件。

以下範例使用 dnf

配置套件註冊表

要註冊 RPM 註冊表,請將 URL 添加到已知來源列表中:

dnf config-manager --add-repo https://gitea.example.com/api/packages/{owner}/rpm/{group}.repo
佔位符描述
owner套件的擁有者。
group可選:所有內容,例如空的,el7rocky/el9test/fc38

範例:

# 沒有分組
dnf config-manager --add-repo https://gitea.example.com/api/packages/testuser/rpm.repo

# 使用分組 'centos/el7'
dnf config-manager --add-repo https://gitea.example.com/api/packages/testuser/rpm/centos/el7.repo

如果註冊表是私有的,請在 URL 中提供憑證。您可以使用密碼或 個人訪問令牌

dnf config-manager --add-repo https://{username}:{your_password_or_token}@gitea.example.com/api/packages/{owner}/rpm/{group}.repo

您還需要將憑證添加到創建的 .repo 文件中的 URL 中,位於 /etc/yum.repos.d

發布套件

要發布 RPM 套件(*.rpm),請執行 HTTP PUT 操作,請求體中包含套件內容。

PUT https://gitea.example.com/api/packages/{owner}/rpm/{group}/upload
參數描述
owner套件的擁有者。
group可選:所有內容,例如空的,el7rocky/el9test/fc38

使用 HTTP 基本身份驗證的範例請求:

# 沒有分組
curl --user your_username:your_password_or_token \
--upload-file path/to/file.rpm \
https://gitea.example.com/api/packages/testuser/rpm/upload

# 使用分組 'centos/el7'
curl --user your_username:your_password_or_token \
--upload-file path/to/file.rpm \
https://gitea.example.com/api/packages/testuser/rpm/centos/el7/upload

如果您使用 2FA 或 OAuth,請使用 個人訪問令牌 代替密碼。 您不能將同名文件兩次發布到套件中。您必須先刪除現有的套件版本。

服務器響應以下 HTTP 狀態碼。

HTTP 狀態碼含義
201 Created套件已發布。
400 Bad Request套件無效。
409 Conflict套件中已存在具有相同參數組合的文件。

刪除套件

要刪除 RPM 套件,請執行 HTTP DELETE 操作。如果沒有文件剩餘,這也會刪除套件版本。

DELETE https://gitea.example.com/api/packages/{owner}/rpm/{group}/package/{package_name}/{package_version}/{architecture}
參數描述
owner套件的擁有者。
group可選:套件分組。
package_name套件名稱。
package_version套件版本。
architecture套件架構。

使用 HTTP 基本身份驗證的範例請求:

# 沒有分組
curl --user your_username:your_token_or_password -X DELETE \
https://gitea.example.com/api/packages/testuser/rpm/package/test-package/1.0.0/x86_64

# 使用分組 'centos/el7'
curl --user your_username:your_token_or_password -X DELETE \
https://gitea.example.com/api/packages/testuser/rpm/centos/el7/package/test-package/1.0.0/x86_64

服務器響應以下 HTTP 狀態碼。

HTTP 狀態碼含義
204 No Content成功
404 Not Found未找到套件或文件。

安裝套件

要從 RPM 註冊表中安裝套件,請執行以下命令:

# 使用最新版本
dnf install {package_name}
# 使用特定版本
dnf install {package_name}-{package_version}.{architecture}