Git 删除远程分支有以下几种方法
服务端UI工具
Git 的服务端图形化工具主要是 web 端。常用的有 GitHub、Gitea、Gutlab 等。
这些工具都提供了分支管理,可以直接在各服务端找到相关功能,谨慎删除。
客户端UI工具
Git 拥有诸多客户端 UI 工具,如官方自带的 GitUI、Sublim-Merge及各种编辑器(Eclipse、VSCode、Idea等)集成的UI工具等。
这些 UI 工具提供了更加便捷的分支管理功能,能支持分支的删除。
命令行
命令行删除是本文重点阐述的一种方式。
命令通过引用规范从远程服务器上删除
git push origin :dev
因为引用规范(的格式)是 :,所以上述命令把 留空,意味着把远程版本库的 dev 分支定义为空值,也就是删除它。
引用规范
现在想要添加一个远程仓库:
git remote add origin https://github.com/schacon/simplegit-progit
运行上述命令会在你仓库中的 .git/config 文件中添加一个小节, 并在其中指定远程版本库的名称(origin)、URL 和一个用于获取操作的 引用规范(refspec):[remote "origin"] url = https://github.com/schacon/simplegit-progit fetch = +refs/heads/*:refs/remotes/origin/*
引用规范的格式由一个可选的 + 号和紧随其后的 : 组成, 其中 是一个模式(pattern),代表远程版本库中的引用; 是本地跟踪的远程引用的位置。 + 号告诉 Git 即使在不能快进的情况下也要(强制)更新引用。
默认情况下,引用规范由 git remote add origin 命令自动生成, Git 获取服务器中 refs/heads/ 下面的所有引用,并将它写入到本地的 refs/remotes/origin/ 中。 所以,如果服务器上有一个 master 分支,你可以在本地通过下面任意一种方式来访问该分支上的提交记录:
git log origin/mastergit log remotes/origin/mastergit log refs/remotes/origin/master
上面的三个命令作用相同,因为 Git 会把它们都扩展成 refs/remotes/origin/master。
更多引用规范请参考:GIT 内部原理-引用规范
git push 语法
或者你可以使用更新的语法(自 Git v1.7.0 以后可用)
git push origin --delete dev
使用 JGit 删除
private static void deleteRemoteBranch(CredentialsProvider credentialsProvider, Git git) throws GitAPIException { String deleteBranch = "dev"; RefSpec refSpec = new RefSpec() .setSource(null) .setDestination("refs/heads/" + deleteBranch); Iterable<PushResult> results = git.push() .setCredentialsProvider(credentialsProvider) .setRemote("origin") .setRefSpecs(refSpec) .call(); // 处理推送结果 for (PushResult result : results) { for (RemoteRefUpdate update : result.getRemoteUpdates()) { System.out.println("Status: " + update.getStatus()); } } }
以上代码摘自 【JGit】分支管理实践
其原理是使用了通过引用规范从远程服务器上删除,即git push origin :dev
。