directory search
Guides gitattributes giteveryday gitglossary gitignore gitmodules gitrevisions gittutorial gitworkflows Administration git archive git bundle git clean git filter-branch git fsck git gc git instaweb git reflog Basic Snapshotting git add git commit git diff git mv git reset git rm git status Branching and Merging git branch git checkout git log git merge git mergetool git stash git tag Debugging git bisect git blame git grep Email git am git format-patch git request-pull git send-email External Systems git fast-import git svn Getting and Creating Projects git clone git init Git git annotate git archimport git bisect-lk2009 git check-attr git check-mailmap git check-ref-format git checkout-index git cherry git citool git column git credential git credential-cache git credential-store git cvsexportcommit git cvsimport git cvsserver git diff-files git diff-tree git difftool git fast-export git fetch-pack git fmt-merge-msg git get-tar-commit-id git gui git http-backend git http-fetch git http-push git imap-send git index-pack git interpret-trailers git ls-remote git ls-tree git mailinfo git mailsplit git merge-file git merge-index git merge-one-file git merge-tree git mktag git mktree git name-rev git notes git p4 git pack-objects git pack-redundant git pack-refs git parse-remote git patch-id git prune git prune-packed git quiltimport git receive-pack git remote-ext git remote-fd git remote-testgit git repack git replace git rerere git send-pack git sh-i18n git sh-setup git shell git show-branch git show-index git stripspace git unpack-file git unpack-objects git upload-archive git upload-pack git var git verify-commit git verify-tag git whatchanged git worktree Inspection and Comparison git describe git shortlog git show Miscellaneous api credentials api index gitcli gitcore tutorial gitcredentials gitcvs migration gitdiffcore githooks gitk gitnamespaces gitremote helpers gitrepository layout gitsubmodules gittutorial 2 gitweb gitweb.conf pack format User Manual Patching git apply git cherry-pick git rebase git revert Plumbing Commands git cat-file git check-ignore git commit-tree git count-objects git diff-index git for-each-ref git hash-object git ls-files git merge-base git read-tree git rev-list git rev-parse git show-ref git symbolic-ref git update-index git update-ref git verify-pack git write-tree Server Admin git daemon git update-server-info Setup and Config git git config git help Sharing and Updating Projects git fetch git pull git push git remote git submodule
characters

命名

gitrepository-layout - Git Repository Layout

概要

$GIT_DIR/*

描述

一个 Git 仓库有两种不同的风格:

  • 一个.git目录在工作树的根;

  • 一个.gitbare存储库的目录(即没有自己的工作树),通常用于与其他人交换历史记录,方法是将其推入并从中取回。

注意:您也可以在工作树的根目录中有一个纯文本文件.git,其中包含gitdir: 指向具有存储库的实际目录。此机制通常用于子模块签出的工作树,以允许您在包含超级项目的情况下访问git checkout没有子模块的分支。将checkout有权删除整个子模块工作树,又不失子模块库。

这些东西可能存在于 Git 仓库中。

objects

与此存储库关联的对象存储。通常一个对象存储是自给自足的(即,在其中找到的对象所引用的所有对象也可以在其中找到),但有几种方法可以违反它。

1. 通过创建浅度克隆,您可以拥有一个不完整但本地可用的存储库。参见 git-clone [1] 。

2. 您可以使用objects/info/alternates$GIT_ALTERNATE_OBJECT_DIRECTORIES机制来borrow从其他对象存储的对象。具有这种不完整对象存储库的存储库不适合被发布以用于哑输送,但是只要objects/info/alternates对象所存储的点存储于其中,则其他就可以。

如果设置了 $ GIT_COMMON_DIR 并且将使用 “$ GIT_COMMON_DIR / objects” ,则该目录将被忽略。

objects/0-9a-f

新创建的对象存储在其自己的文件中。这些对象使用 sha1 对象名称的前两个字符显示在256个子目录中,以将目录条目objects本身的数量保持为可管理的数量。在这里找到的对象通常被称为unpacked(或loose)对象。

objects/pack

打包(在压缩格式中存储多个对象的文件以及允许它们随机访问的索引文件)可在此目录中找到。

objects/info

有关对象存储的其他信息记录在此目录中。

objects/info/packs

这个文件是为了帮助笨拙的传输发现在这个对象存储中可用的包。无论何时添加或删除包,git update-server-info都应该运行以保持该文件最新,如果存储库针对哑传输发布的话。git repack这是默认情况下。

objects/info/alternates

此文件记录此对象存储借用对象的备用对象存储的路径,每行一个路径名。请注意,不仅本地 Git 工具在本地使用它,而且 HTTP fetcher 也会尝试远程使用它; 如果在替代文件中有相对路径(相对于对象数据库,而不是存储库!),这通常会起作用,但如果使用绝对路径,它将不起作用,除非文件系统和 Web URL 中的绝对路径相同。另见objects/info/http-alternates

objects/info/http-alternates

该文件将 URL 记录到此对象存储借用对象的备用对象存储中,以便在通过 HTTP 获取存储库时使用。

refs

引用存储在此目录的子目录中。该git prune命令知道保留可从此目录及其子目录中找到的引用可访问的对象。如果设置了 $ GIT_COMMON_DIR 并且将使用 “$ GIT_COMMON_DIR / refs” ,则该目录将被忽略。

refs/heads/name

记录树枝的树枝提交对象name

refs/tags/name

记录任何对象名称(不一定是提交对象,或指向提交对象的标记对象)。

refs/remotes/name

记录从远程存储库复制的分支的树形提交对象。

refs/replace/

记录替换对象的 SHA-1。这与 info / grafts 类似,并且由 git-replace [1] 在内部使用和维护。这些参考文献可以在库之间进行交换,而移植不是。

packed-refs

记录与 refs / heads /,refs / tags / 相同的信息,并以更高效的方式记录朋友。参见 git-pack-refs [1] 。如果设置了 $ GIT_COMMON_DIR 并且将使用 “$ GIT_COMMON_DIR / packed-refs” ,那么该文件将被忽略。

HEAD

refs/heads/描述当前活动分支的命名空间的 symref(参见词汇表)。如果存储库不与任何工作树(即bare存储库)相关联,这并没有多大意义,但有效的 Git 存储库必须具有 HEAD 文件; 一些瓷器可能会用它来猜测储存库的指定“默认”分支(通常master)。如果指定的分支name尚未(尚未)存在,则是合法的。在一些传统设置中,它是一个符号链接,而不是指向当前分支的 symref 。

HEAD 还可以直接记录特定的提交,而不是作为 symref 指向当前分支。detached HEAD.有关详细信息,此类状态通常称为参阅 git-checkout [1] 。

config

存储库特定的配置文件。如果设置了 $ GIT_COMMON_DIR 并且将使用 “$ GIT_COMMON_DIR / config” ,则忽略此文件。

branches

存储用于指定 URL 的简写方式git fetchgit pull以及git push。一个文件可以存储为branches/,然后name可以给这些命令代替repository参数。有关详细信息,请参阅 git-fetch [1] 中的 REMOTES 部分。这种机制是传统的,不太可能在现代仓库中找到。如果设置了 $ GIT_COMMON_DIR 并且将使用 “$ GIT_COMMON_DIR / branches” ,则该目录将被忽略。

hooks

钩子是各种 Git 命令使用的定制脚本。git init运行时会安装一些示例挂钩,但默认情况下它们都被禁用。要启用,.sample后缀必须通过重命名从文件名中删除。阅读 githooks [5] 了解每个钩子的更多细节。如果设置了 $ GIT_COMMON_DIR 并且将使用 “$ GIT_COMMON_DIR / hooks” ,则该目录将被忽略。

index

存储库的当前索引文件。它通常在空仓库中找不到。

sharedindex.

共享索引部分,由 $ GIT_DIR / index 和其他临时索引文件引用。仅在分割索引模式下有效。

info

有关存储库的其他信息记录在此目录中。如果设置了 $ GIT_COMMON_DIR 并且将使用 “$ GIT_COMMON_DIR / info” ,则该目录将被忽略。

info/refs

这个文件有助于常用的传输发现这个仓库中可用的参考文献。如果存储库针对哑传输发布,则git update-server-info每次创建或修改标签或分支时都应该重新生成该文件。这通常是从hooks/update挂钩中完成的,挂钩git-receive-pack在您git push进入存储库时由命令运行。

info/grafts

这个文件记录假提交上代信息,假装一个提交具有不同于提交实际创建的父集。每行一条记录通过列出由空格分隔并以换行符结尾的40字节十六进制对象名称来描述提交及其假父代。

请注意,移植机制已过时,并可能导致在库之间传输对象时出现问题; 请参阅 git-replace [1] 以获得更灵活和更强大的系统来完成同样的任务。

info/exclude

该文件按照 Porcelains 中的惯例存储排除模式列表。.gitignore是每个目录的忽略文件。git statusgit addgit rm并且git clean看着它,但核心的 Git 命令不看它。另见:gitignore [5]。

info/sparse-checkout

该文件存储稀疏切换分支模式。另请参阅:git-read-tree [1]。

remotes

商店简写为使用通过远程仓库进行交互时,URL 和默认 refnamesgit fetchgit pullgit push命令。有关详细信息,请参阅 git-fetch [1] 中的 REMOTES 部分。这种机制是传统的,不太可能在现代仓库中找到。如果设置了 $ GIT_COMMON_DIR 并且将使用 “$ GIT_COMMON_DIR / remotes” ,则该目录将被忽略。

logs

对 ref 进行的更改记录存储在此目录中。有关更多信息,请参阅 git-update-ref [1] 。如果设置了 $ GIT_COMMON_DIR 并且将使用 “$ GIT_COMMON_DIR / logs” ,则该目录将被忽略。

logs/refs/heads/name

记录对分支提示进行的所有更改name

logs/refs/tags/name

记录对名为name的标签所做的所有更改。

shallow

这与info/grafts浅层克隆机制类似,但在内部使用和维护。请参阅--depthgit-clone [1] 和 git-fetch [1] 的选项。如果设置了 $ GIT_COMMON_DIR 并且将使用 “$ GIT_COMMON_DIR / shallow” ,则该文件将被忽略。

commondir

如果此文件存在,$ GIT_COMMON_DIR(请参阅 git [1] )将被设置为此文件中指定的路径(如果未明确设置)。如果指定的路径是相对的,则相对于 $ GIT_DIR 。如果没有 “commondir” 指向的存储库,commondir 存储库是不完整的。

modules

包含子模块的 git-repository 。

worktrees

包含链接工作树的管理数据。每个子目录都包含链接工作树的工作树相关部分。如果设置了 $ GIT_COMMON_DIR ,则该目录将被忽略,在这种情况下,将使用 “$ GIT_COMMON_DIR / worktrees” 。

worktrees//gitdir

包含指向此处的 .git 文件的绝对路径的文本文件。这用于检查链接的存储库是否已被手动删除,并且不需要保留该目录。每次访问链接存储库时都应更新此文件的 mtime 。

worktrees//locked

如果此文件存在,则链接的工作树可能位于便携式设备上并且不可用。这个文件的存在防止worktrees/被自动或手动修剪git worktree prune。该文件可能包含一个字符串,解释存储库被锁定的原因。

worktrees//link

如果此文件存在,则它是到链接的 .git 文件的硬链接。它用于检测是否手动删除链接的存储库。

Previous article: Next article: