简体中文 ▾ 主题 ▾ 最新版本 ▾ scalar 上次更新于 2.52.0

名称

scalar - 管理大型 Git 仓库的工具

概要

scalar clone [--single-branch] [--branch <main-branch>] [--full-clone]
	[--[no-]src] [--[no-]tags] [--[no-]maintenance] <url> [<enlistment>]
scalar list
scalar register [--[no-]maintenance] [<enlistment>]
scalar unregister [<enlistment>]
scalar run ( all | config | commit-graph | fetch | loose-objects | pack-files ) [<enlistment>]
scalar reconfigure [--maintenance=(enable|disable|keep)] [ --all | <enlistment> ]
scalar diagnose [<enlistment>]
scalar delete <enlistment>

描述

Scalar 是一款用于优化 Git 以在大型仓库中使用的仓库管理工具。Scalar 通过配置高级 Git 设置、在后台维护仓库以及帮助减少网络传输数据来提高性能。

Scalar 的一个重要概念是 enlistment(注册):这是项目的顶层目录。它通常包含 src/ 子目录,这是一个 Git 工作树。这鼓励了跟踪文件(位于 src/ 内)和未跟踪文件(例如构建产物,位于 src/ 外)之间的分离。当使用 Scalar 注册现有 Git 工作树时,如果其名称不是 src,则 enlistment 将与工作树相同。

scalar 命令实现了各种子命令,并且根据子命令有不同的选项。除了 clonelistreconfigure --all 之外,所有子命令都期望在 enlistment 中运行。

以下选项可以在子命令之前指定

-C <directory>

在运行子命令之前,更改当前工作目录。此选项模仿了 git[1] 的同名选项。

-c <key>=<value>

在运行指定子命令的期间,配置此设置。此选项模仿了 git[1] 的同名选项。

命令

Clone

clone [<options>] <url> [<enlistment>]

克隆指定的仓库,类似于 git-clone[1]。默认情况下,仅克隆提交和树对象。完成后,工作树位于 <enlistment>/src

稀疏检出功能已启用(除非与 --full-clone 一起运行),并且仅存在顶层目录中的文件。使用 git sparse-checkout set 展开您想要查看的目录集,或使用 git sparse-checkout disable 展开到所有文件(有关更多详细信息,请参阅 git-sparse-checkout[1])。您可以使用 git ls-tree HEAD[:<directory>] 来探索稀疏检出之外的子目录。

-b <name>
--branch <name>

代替检出克隆仓库 HEAD 指向的分支,而是检出 <name> 分支。

--single-branch
--no-single-branch

仅克隆指向单个分支尖端的历史记录,该分支由 --branch 选项指定,或由远程的 HEAD 指向的主分支。

对结果仓库的进一步获取将仅更新用于初始克隆时使用此选项的分支的远程跟踪分支。如果在进行 --single-branch 克隆时,远程的 HEAD 未指向任何分支,则不会创建远程跟踪分支。

--src
--no-src

默认情况下,scalar clone 将克隆的仓库放置在 <entlistment>/src 目录内。使用 --no-src 将克隆的仓库直接放置在 <enlistment> 目录中。

--tags
--no-tags

默认情况下,scalar clone 将获取远程提供的标签对象,并且未来的 git fetch 命令也将如此。使用 --no-tags 避免在 scalar clone 中获取标签,并配置仓库以避免将来获取标签。要使用 --no-tags 克隆后获取标签,请运行 git fetch --tags

--full-clone
--no-full-clone

默认初始化稀疏检出。此行为可以通过 --full-clone 关闭。

--maintenance
--no-maintenance

默认情况下,scalar clone 配置 enlistment 以使用 Git 的后台维护功能。使用 --no-maintenance 跳过此配置。

List

list

列出当前由 Scalar 注册的 enlistments。此子命令不需要在 enlistment 中运行。

Register

register [<enlistment>]

将 enlistment 的仓库添加到注册仓库列表并开始后台维护。如果未提供 <enlistment>,则注册与当前工作目录关联的 enlistment。

注意:当此子命令在名为 src/ 的工作树中调用时,其父目录被视为 Scalar enlistment。如果工作树名为 src/,则它本身将被视为 Scalar enlistment。

--maintenance
--no-maintenance

默认情况下,scalar register 配置 enlistment 以使用 Git 的后台维护功能。使用 --no-maintenance 跳过此配置。这不会禁用任何可能已通过其他方式启用的维护。

Unregister

unregister [<enlistment>]

从 Scalar 注册的仓库列表中移除指定的仓库,并停止计划的后台维护。

Run

scalar run ( all | config | commit-graph | fetch | loose-objects | pack-files ) [<enlistment>]

运行给定的维护任务(如果指定了 all,则运行所有任务)。除了 all 和 config 之外,此子命令直接移交给 git-maintenance[1](将 fetch 映射到 prefetch,将 pack-files 映射到 incremental-repack)。

这些任务作为计划维护的一部分自动运行,一旦仓库被注册到 Scalar。因此,不应手动运行此子命令。

config 任务是 Scalar 特有的,它配置了所有那些能够让 Git 更高效地处理大型仓库的默认设置。由于此任务会自动作为 scalar clone 的一部分运行,因此很少需要显式调用此任务。

Reconfigure

在 Scalar 升级后,或当 Scalar enlistment 的配置因某种原因损坏或被错误更改时,此子命令允许重新配置 enlistment。

--all

当指定 --all 时,重新配置由 scalar.repo 配置键当前注册的所有 enlistments。每次升级后请使用此选项以获取最新功能。

--maintenance=(enable|disable|keep)

默认情况下,Scalar 配置 enlistment 以使用 Git 的后台维护功能;这与使用此选项的 enable 值相同。使用 disable 值可以从后台维护中移除每个考虑到的 enlistment。使用 'keep' 来保持这些仓库的后台维护配置不变。

Diagnose

diagnose [<enlistment>]

在报告 Scalar 相关问题时,提供此命令收集的信息通常很有帮助,包括日志和描述当前 enlistment 数据形状的某些统计信息。

此命令的输出是一个 .zip 文件,该文件被写入 src 目录中工作树的相邻目录。

Delete

delete <enlistment>

此子命令允许您从本地文件系统中删除现有的 Scalar enlistment,并取消注册仓库。

GIT

Git[1] 套件的一部分