跳至主要内容
版本:1.23.6

Cargo 套件註冊表

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

需求

要使用 Cargo 套件註冊表,您需要 Rust 和 Cargo

Cargo 將可用套件的信息存儲在一個 git 存儲庫中的套件索引中。 此存儲庫是使用註冊表所必需的。 以下部分描述了如何創建它。

索引存儲庫

Cargo 將可用套件的信息存儲在一個 git 存儲庫中的套件索引中。 在 Gitea 中,此存儲庫具有特殊名稱 _cargo-index。 上傳套件後,其元數據會自動寫入索引。 此存儲庫的內容不應手動修改。

用戶或組織的套件設置頁面允許創建索引存儲庫以及配置文件。 如果需要,此操作將重寫配置文件。 這在例如 Gitea 實例域名更改時很有用。

如果出現 Gitea 中存儲的套件與索引存儲庫中的信息不同步的情況,設置頁面允許重建索引存儲庫。 此操作會遍歷註冊表中的所有套件並將其信息寫入索引。 如果有很多套件,這個過程可能需要一些時間。

配置套件註冊表

要註冊套件註冊表,必須更新 Cargo 配置。 將以下文本添加到當前用戶主目錄中的配置文件(例如 ~/.cargo/config.toml):

[registry]
default = "gitea"

[registries.gitea]
index = "sparse+https://gitea.example.com/api/packages/{owner}/cargo/" # Sparse index
# index = "https://gitea.example.com/{owner}/_cargo-index.git" # Git

# [net]
# git-fetch-with-cli = true
參數描述
owner套件的擁有者。

如果註冊表是私有的或您想發布新套件,您必須配置您的憑證。 將憑證部分添加到當前用戶主目錄中的憑證文件(例如 ~/.cargo/credentials.toml):

[registries.gitea]
token = "Bearer {token}"
參數描述
token您的 個人訪問令牌

Git vs Sparse

目前,cargo 支持兩種從註冊表中獲取 crate 的方式:Git 索引和 sparse 索引。 Sparse 索引是最新的方法,與 git 相比,在更新 crate 時提供了更好的性能。 自 Rust 1.68 起,sparse 是 crates.io 的默認方法。

發布套件

在您的項目中運行以下命令來發布套件:

cargo publish

如果已經存在同名同版本的套件,您不能發布該套件。您必須先刪除現有的套件。

安裝套件

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

cargo add {package_name}
參數描述
package_name套件名稱。

支持的命令

cargo publish
cargo add
cargo install
cargo yank
cargo unyank
cargo search