我试图弄清楚如何下载 Git 存储库的特定标签 - 它是当前版本之后的一个版本。
我在 git 网页上看到了以前版本的标签,对象名称是长十六进制数字。
但是根据站点,版本名称是“Tagged release 1.1.5
”。
我尝试了这样的命令(更改了名称):
git clone http://git.abc.net/git/abc.git my_abc
我确实得到了一些东西——一个目录、一堆子目录等。
如果它是整个存储库,我如何获得我正在寻找的版本?如果没有,我如何下载该特定版本?
clone -b "Tagged release 1.1.5" http://git.abc.net/git/abs.git my_abc
。当然,这仅在您没有同名的分支时才有效(取决于您的方法,这可能永远不会发生)。
git checkout -b new-branch tag-name
。现在克隆你的新分支。我们可以随时删除新分支。
$ git clone
将为您提供整个存储库。
克隆后,您可以使用 $ git tag -l
列出标签,然后签出特定标签:
$ git checkout tags/<tag_name>
更好的是,签出并创建一个分支(否则您将位于以标签的修订号命名的分支上):
$ git checkout tags/<tag_name> -b <branch_name>
git clone --branch my_abc http://git.abc.net/git/abc.git
将克隆 repo 并将您留在您感兴趣的标签上。
1.8.0 的 git clone 状态的文档。
--branch 还可以在结果存储库中的该提交处获取标签并分离 HEAD。
--depth 1
以避免下载任何非当前提交。
git clone --branch my_abc http://git.abc.net/git/abc.git -b quality
质量是我们想要顺便说一句的分支的名称。
为了只签出给定的部署标签,我使用例如:
git clone -b 'v2.0' --single-branch --depth 1 https://github.com/git/git.git
如果一个人只对最新的代码而不是完整的存储库感兴趣,这似乎是从远程存储库中签出代码的最快方法。这样,它类似于“svn co”命令。
注意:根据 the Git manual,传递 --depth
标志默认为 --single-branch
。
--depth 创建一个浅克隆,其历史记录被截断为指定的提交次数。暗示 --single-branch 除非给出 --no-single-branch 以获取所有分支尖端附近的历史记录。如果你想浅层地克隆子模块,也可以通过 --shallow-submodules。
--depth n
暗示 --single-branch
。你不需要两者。
git clone -b 'v2.0' --quiet --depth 1 https://github.com/git/git.git
但那不起作用。
我不是 git 专家,但我认为这应该可行:
git clone http://git.abc.net/git/abc.git
cd abc
git checkout my_abc
或者
git clone http://git.abc.net/git/abc.git
cd abc
git checkout -b new_branch my_abc
第二个变体基于标签建立一个新的分支,这样你就可以避免“分离的 HEAD”。 (git-checkout manual)
每个 git repo 都包含整个修订历史记录,因此克隆 repo 可以让您访问最新的提交,以及之前的所有内容,包括您正在寻找的标签。
git checkout -b b1.5.0 v1.5.0
。我写的这个 Gist 可能会对其他人有所帮助:分支/标签/子模块... gist.github.com/1064750
cd
进入 abc/
才能签出分支
cd
。
您可以使用 git archive 下载给定标签或提交 id 的 tar 球:
git archive --format=tar --remote=[hostname]:[path to repo] [tag name] > tagged_version.tar
您还可以导出标签的 zip 存档。
列出标签:git tag 0.0.1 0.1.0 导出标签:git archive -o /tmp/my-repo-0.1.0.zip --prefix=my-repo-0.1.0/ 0.1.0 注意:你做不需要指定格式。它将被输出文件名拾取。指定前缀将使您的代码导出到目录(如果包含尾部斜杠)。
git archive
要求我输入密码。如何让它使用 http 而不是 ssh?
fatal: Operation not supported by protocol.
和 Unexpected end of command stream
错误而失败。或者,它也可以返回 fatal: The remote end hung up unexpectedly
错误。
使用 --single-branch
开关 (从 Git 1.7.10 开始可用)。语法是:
git clone -b <tag_name> --single-branch <repo_url> [<dest_dir>]
例如:
git clone -b 'v1.9.5' --single-branch https://github.com/git/git.git git-1.9.5
好处:Git 将接收对象并(需要)仅解析指定分支/标签的增量 - 同时签出完全相同数量的文件!根据源存储库,这将为您节省大量磁盘空间。 (另外,它会更快。)
首先获取该特定遥控器中的所有标签
git fetch <remote> 'refs/tags/*:refs/tags/*'
或者只是简单地输入
git fetch <remote>
然后检查可用的标签
git tag -l
然后使用以下命令切换到该特定标签
git checkout tags/<tag_name>
希望这会帮助你!
git tag
将添加一个标签,而 git tag -l
列出可用标签
如果您的标签可以使用 linux sort
命令排序,请使用以下命令:
git tag | sort -n | tail -1
例如。如果 git tag
返回:
v1.0.1
v1.0.2
v1.0.5
v1.0.4
git tag | sort -n | tail -1
将输出:
v1.0.5
git tag | sort -n | tail -2 | head -1
将输出:
v1.0.4
(因为您要求第二个最近的标签)
要签出标签,首先克隆 repo,然后输入:
git checkout v1.0.4
..或您需要的任何标签。
git for-each-ref --sort='*authordate' --format='%(tag)' refs/tags
git checkout `git tag | sort -n | tail -1`
sort -V
而不是 sort -n
。前者正确处理版本,不一定是数字,例如“1.2.3”。它还理解“0.4.10”在“0.4.1”之后而不是在“0.4.2”之后,-n
会给你。
git fetch <gitserver> <remotetag>:<localtag>
====================================
我只是这样做了。首先,我确定我知道标签名称的拼写。
git ls-remote --tags gitserver; : or origin, whatever your remote is called
这给了我 git 服务器上的标签列表供我选择。原始发帖人已经知道他的标签名称,所以这一步不是每个人都需要的。输出看起来像这样,尽管实际列表更长。
8acb6864d10caa9baf25cc1e4857371efb01f7cd refs/tags/v5.2.2.2
f4ba9d79e3d760f1990c2117187b5010e92e1ea2 refs/tags/v5.2.3.1
8dd05466201b51fcaf4ca85897347d82fcb29518 refs/tags/Fix_109
9b5087090d9077c10ba22d99d5ce90d8a45c50a3 refs/tags/Fix_110
我选择了我想要的标签并获取了它,仅此而已。
git fetch gitserver Fix_110
然后我在我的本地机器上标记了这个,给我的标签取了相同的名字。
git tag Fix_110 FETCH_HEAD
我不想像其他人建议的那样克隆远程存储库,因为我正在处理的项目很大,我想在一个干净的环境中进行开发。我觉得这比建议克隆整个存储库的解决方案更接近原始问题“我试图弄清楚如何下载特定标签”。我不明白为什么任何人如果想查看 DOS 0.1 源代码(例如)就必须拥有 Windows NT 和 Windows 8.1 源代码的副本。
我也不想像其他人建议的那样使用 CHECKOUT。我有一个分支检查出来,不想影响它。我的目的是获取我想要的软件,以便我可以挑选一些东西并将其添加到我的开发中。
可能有一种方法可以获取标记本身,而不仅仅是被标记的提交的副本。我必须自己标记获取的提交。编辑:啊,是的,我现在找到了。
git fetch gitserver Fix_110:Fix_110
您在哪里看到冒号,即远程名称:本地名称,这里它们是标签名称。这运行不会打乱工作树等。它似乎只是将东西从远程复制到本地机器,所以你有自己的副本。
git fetch gitserver --dry-run Fix_110:Fix_110
添加 --dry-run 选项后,您可以查看该命令的功能,如果您想验证它是您想要的。所以我想一个简单的
git fetch gitserver remotetag:localtag
是真正的答案。
=
关于标签的单独说明......当我开始新事物时,我通常在 git init 之后标记空存储库,因为
git rebase -i XXXXX
需要提交,问题就出现了“你如何重新调整包含你的第一个软件更改的更改?”所以当我开始工作时
git init
touch .gitignore
[then add it and commit it, and finally]
git tag EMPTY
即在我第一次真正更改之前创建一个提交,然后再使用
git rebase -i EMPTY
如果我想重新调整我所有的工作,包括第一次更改。
我检查了 git checkout documentation,它揭示了一件有趣的事情:
git checkout -b
所以我们可以提到标签名称(因为标签只不过是提交的名称),比如:
>> git checkout -b 1.0.2_branch 1.0.2 以后,修改一些文件 >> git push --tags
PS:在Git中,你不能直接更新一个标签(因为标签只是一个提交的标签),你需要签出与分支相同的标签,然后提交到它,然后创建一个单独的标签。
根据 Peter Johnson 的回答,我为自己创建了一个不错的小别名:
alias gcolt="git checkout $(git tag | sort -V | tail -1)"
又名“git checkout 最新标签”。
这依赖于 GNU 版本的 sort,它可以适当地处理像 lOranger 指出的情况:
v1.0.1
...
v1.0.9
v1.0.10
如果您使用的是 Mac,请 brew install coreutils
然后调用 gsort。
尝试:
git clone -b <name_of_the_tag> <repository_url> <destination>
如果你想查看一个标签指向的文件的版本,你可以做一个 git checkout,虽然这会使你的存储库处于“分离的 HEAD”状态,这有一些不良的副作用:
$ git checkout 2.0.0
Note: checking out '2.0.0'.
You are in 'detached HEAD' state. You can look around, make experimental
changes and commit them, and you can discard any commits you make in this
state without impacting any branches by performing another checkout.
If you want to create a new branch to retain commits you create, you may
do so (now or later) by using -b with the checkout command again. Example:
git checkout -b <new-branch-name>
HEAD is now at 99ada87... Merge pull request #89 from schacon/appendix-final
$ git checkout 2.0-beta-0.1
Previous HEAD position was 99ada87... Merge pull request #89 from schacon/appendix-final
HEAD is now at df3f601... add atlas.json and cover image
在“分离的 HEAD”状态下,如果您进行更改然后创建提交,标签将保持不变,但您的新提交将不属于任何分支并且将无法访问,除非通过确切的提交哈希。因此,如果您需要进行更改(例如,您正在修复旧版本上的错误),您通常需要创建一个分支:
$ git checkout -b version2 v2.0.0
Switched to a new branch 'version2'
如果您这样做并提交,您的 version2 分支将与您的 v2.0.0 标记略有不同,因为它会随着您的新更改向前移动,所以要小心。
我这样做是通过 github API:
curl -H "Authorization: token %(access_token)s" -sL -o /tmp/repo.tar.gz "http://api.github.com/repos/%(organisation)s/%(repo)s/tarball/%(tag)s" ;\
tar xfz /tmp/repo.tar.gz -C /tmp/repo --strip-components=1 ; \
我经常用一个
git clone --branch <tag_name> <repo_url>
我做了如下
git checkout tags/20210511 -b 20210511-release
-b
标志告诉 git 创建一个新分支并指定一个分支名称:git checkout <tag_name> -b <branch_name>
1.8.3.5
和更高版本中,--branch <tag ref>
应该允许您从<tag ref>
开始下载存储库作为 repo HEAD;结合--depth 1
将进行浅标签结帐。请参阅stackoverflow.com/a/21699307/1695680