我们在git中使用标签作为部署过程的一部分。有时,我们希望通过从远程存储库中删除这些标记来清理它们。

这很简单。一个用户在一组命令中删除了本地标签和远程标签。我们有一个结合了这两个步骤的shell脚本。

第二个(第3个,第4个,……)用户现在拥有不再反映在远程上的本地标记。

我正在寻找一个类似于git远程修剪起源的命令,清理本地跟踪分支,其中远程分支已被删除。

或者,可以使用一个简单的命令来列出远程标记,与通过git tag -l返回的本地标记进行比较。


当前回答

从Git v1.7.8到v1.8.5.6,你可以这样使用:

git fetch <remote> --prune --tags

更新

这在较新的git版本(从v1.9.0开始)上不起作用,因为提交了e66ef7ae6f31f2。我并不想删除它,因为它确实对一些人有用。

根据“Chad Juliano”的建议,对于v1.7.8以来的所有Git版本,您可以使用以下命令:

git fetch --prune <remote> +refs/tags/*:refs/tags/*

你可能需要用引号将标签部分括起来(例如在Windows上),以避免通配符展开:

git fetch --prune <remote> "+refs/tags/*:refs/tags/*"

注意:在所有这些情况下,可能是“origin”或任何您通常引用的远程。

其他回答

Git本身支持清除本地标记

git fetch --tags --prune-tags

该命令提取最新的标记并删除所有已删除的标记

自v1.7.8以来的所有版本的Git都理解使用refspec来获取Git,而自v1.9.0以来——tags选项覆盖了——prune选项。对于一个通用的解决方案,试试这个:

$ git --version
git version 2.1.3

$ git fetch --prune origin "+refs/tags/*:refs/tags/*"
From ssh://xxx
 x [deleted]         (none)     -> rel_test

有关“——tags”和“——prune”行为在Git v1.9.0中如何改变的进一步阅读,请参见:https://github.com/git/git/commit/e66ef7ae6f31f246dead62f574cc2acb75fd001c

这是个好问题,我也一直在想同样的问题。

我不想写一个脚本,所以寻求一个不同的解决方案。关键是发现可以在本地删除标记,然后使用git fetch从远程服务器“取回”它。如果标签在远程上不存在,那么它将保持删除状态。

因此你需要按顺序输入两行:

git tag -l | xargs git tag -d
git fetch --tags

这些:

从本地回收中删除所有标签。总之,xargs将每个通过“tag -l”输出的标记放到“tag -d”的命令行上。没有这个,git不会删除任何东西,因为它不读取stdin(愚蠢的git)。 从远程回收中获取所有活动标记。

这甚至在Windows上也很有效。

TortoiseGit现在可以比较标签了。

左边是远程日志,右边是本地日志。

使用同步对话框的比较标签功能:

另见TortoiseGit 2973期

更新@2021/05

将$REPO参数传递给自定义脚本。

sync_git_tags.sh的内容

#!/bin/sh

# cd to $REPO directory
cd $1
pwd

# sync remote tags
git tag -l | xargs git tag -d && git fetch -t

Old

ps:更新@2021/05,git获取-修剪-修剪标签来源不工作在我的MacOS。

我将该命令作为MacOS上的自定义操作添加到SourceTree。 通过Sourcetree -> Preferences设置自定义操作…->自定义动作


`Script to run` have to be the `git` path.

我使用git fetch -prune- prune-tags origin来同步标签从远程到本地。