假设我们有一个稳定的应用程序。
明天,有人报告了一个大漏洞,我们决定立即进行热修复。因此,我们为“master”创建了一个修复分支,我们将其命名为“2011_Hotfix”,并将其推高,以便所有开发人员可以协作修复它。
我们修复了这个错误,并将“2011_Hotfix”合并到“master”以及当前的开发分支中。然后按“主键”。
我们现在对“2011_Hotfix”做什么?它是应该永远作为一个分支存在,直到时间的尽头,还是我们现在应该删除它,因为它已经达到了它的目的?让分支到处乱放似乎是不干净的,因为分支列表可能会变得很长,其中大多数甚至不再需要了。
如果它被删除,它的历史会发生什么?即使实际的分支不再可用,它也会得到维护吗?另外,如何删除远程分支?
似乎您希望在不丢失其历史记录的情况下删除2011_Hotfix分支。我将首先讨论删除,然后讨论历史。
上面已经描述了常用的git分支删除方法,它们可以正常工作。git没有一个或两个单词的命令,意思是“嘿,git,删除本地和远程分支”。但是这种行为可以通过shell脚本来模仿。以Zach Holman的shell脚本“git-nuke”为例。这很简单:
#!/bin/sh
git branch -D $1
git push origin :$1
把它放在一个可执行文件(例如git-nuke)中,放在你的$PATH目录中。如果您不在2011_Hotfix分支上,那么只需运行git-nuke 2011_Hotfix即可删除本地和远程分支。这比标准的git命令更快更简单——尽管可能更危险。
你对保护历史的关心是对的。在这种情况下,你不必担心。一旦你将2011_Hotfix合并到master上,所有来自2011_Hotfix的提交都会被添加到master的提交历史中。简而言之,简单的合并不会丢失历史记录。
I have one more word to add that is perhaps beyond the scope of your question, but is relevant nonetheless. Let's imagine that there are 20 tiny, "work-in-progress" commits on 2011_Hotfix; however, you want only one complete commit for 2011_Hotfix to be added to master's history. How do you combine all 20 small commits into one big commit? Fortunately, git allows you to consolidate multiple commits into one commit by using git-rebase. I won't explain here how that works; though, if you're interested, the documentation for git-rebase is excellent. Do note that git rebase rewrites history, so it should be used judiciously, especially if you are new to it. Finally, your 2011_Hotfix scenario is about a dev team, not a solo dev. If project team members use git rebase, it is wise for the team to have explicit guidelines on the use of git rebase in order that some cowboy dev on the team doesn't unwittingly damage a project's git's history.
你需要做的是标记你释放的任何东西。在你积极开发的时候保留分支。
删除旧的分支
git branch -d branch_name
将它们从服务器中删除
git push origin --delete branch_name
或者旧的语法
git push origin :branch_name
它读起来是“在原点上将任何东西推入branch_name”。
也就是说,只要DAG(有向无环图)可以指向它,提交就会在历史记录中出现。
谷歌的“git-flow”,这可能会提供更多关于发布管理、分支和标签的见解。