git 会保留所有的提交吗?不会!
遇到了一个坑,有人把 git 分支删了。
场景还原#
很久之前,小A 在仓库中提交了代码,分支为 t/xiaoa,并推送到了远程仓库。
一段时间之后,一个小B 同学,清理远程仓库的分支,把 t/xiaoa 分支删除了。
小C 同学拉下远程仓库,想要找 t/xiaoa 分支,没有。从部署记录中找到了 t/xiaoa 分支对应的 commit id(e.g. 388f6e63)
使用 git checkout 388f6e63
切换到对应提交,提示:
找不到啦!
原因#
如果没有任何分支或TAG包含/指向某个提交,那么这个提交被清理掉了,如果本地有历史记录还可能找回来,但如果是 小C 同学这种场景,是全新拉取仓库,是找不回来的了。
最后怎么解决的#
找到另外一个同学小D,小D同学的电脑上,有仓库被清理之前的分支记录,所以还是能找回来的。
有什么经验可以获得#
1 不要任性地清理仓库分支,除非分支已经合并到了主分支
2 对于发布的功能,打 tag
于我个人而言,我之前拉取仓库时,习惯使用 git fetch -p
,这个 -p(prune)
会清理掉哪些在远端已经删除的分支。
看来还是用 git fetch
就好,在本地保留更多的历史记录,以备不测。
上面的案例中,如果小D同学日常使用 git fetch -p
更新本地仓库,那么他本地的 origin/t/xiaoa
分支也会被清理掉,就找不到了。
参考文章:
git log - Get a list of all git commits, including the 'lost' ones - Stack Overflow
作者:
J.晒太阳的猫
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接,否则保留追究法律责任的权利。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具