0
0
mirror of https://gitea.com/gitea/docs.git synced 2025-05-10 22:15:06 +00:00
Files
appleboy dbfa0ba454 docs: add zh-tw folder (#195)
Signed-off-by: appleboy <appleboy.tw@gmail.com>
Reviewed-on: https://gitea.com/gitea/docs/pulls/195
Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com>
Co-authored-by: appleboy <appleboy.tw@gmail.com>
Co-committed-by: appleboy <appleboy.tw@gmail.com>
2025-04-04 23:28:16 +00:00

4.4 KiB
Raw Permalink Blame History

date, slug, sidebar_position
date slug sidebar_position
2023-03-08T00:00:00+00:00 rpm 105

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}