[git] 如何处理push失败的commit

在使用git及github时,遇到一个问题:commit了一个超过100M的大文件,然后在push时失败,然后就再也无法push了,本地大文件删除了,再commit,再push也还是提示有大文件提交。

这是一种非常常见的问题,是典型案例,原因是本地对大文件的commit记录还在,后来虽然remove了大文件并再次commit,但并不能抹除第一次对大文件的commit记录,因此push时相当于依次执行 commit 大文件,commit remove大文件操作,故失败。

 

解决方法:

1,先保存好本地已经commit但还没有push的版本,

2,本地回退到commit大文件的前一版本,此版本往后的所有本地commit都被抹除了(这就是做步骤1的原因)

3,pull到最新版本

4,将1的东西重新commit上去

5,push

这样就从版本中抹除了 大文件提交的纪录

 

ps: 步2在tortoiseGit右键菜单中是 reset master to this

posted @   时空观察者9号  阅读(2633)  评论(0编辑  收藏  举报
编辑推荐:
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
· dotnet 源代码生成器分析器入门
· ASP.NET Core 模型验证消息的本地化新姿势
阅读排行:
· ThreeJs-16智慧城市项目(重磅以及未来发展ai)
· .NET 原生驾驭 AI 新基建实战系列(一):向量数据库的应用与畅想
· Ai满嘴顺口溜,想考研?浪费我几个小时
· Browser-use 详细介绍&使用文档
· 软件产品开发中常见的10个问题及处理方法
历史上的今天:
2017-09-22 UNITY Destroy()和DestroyImadiate()都不会立即释放对象内存
2017-09-22 关于LOH(Large Object Heap)及内存泄漏
点击右上角即可分享
微信分享提示