Git不小心commit了很大的文件怎么办?

Git不小心commit了很大的文件怎么办?,第1张

1 git add . 2 git commit -m 3 git pull 4 git push

拉闸,不小心commit了超过10M的文件,拉闸。 出现了一个错误。

这时候不小心将一个很大的文件添加到库中,即使删除,记录中还是保存了这个文件。以后不管是拷贝,还是push/pull都比较麻烦,尤其是在做CI时的耗时很痛苦。

1、若知道你的大文件是什么类型的,比如.gz或者.jar等,可以删除匹配xxx的所有文件:比如我很明显就提示我是xxx.jar 太大了。 因为我打了整个项目的jar包,接近100MB肯定大

2、若不知道,想查看下目前git库中有哪些大文件,可以用底层命令verify-pack识别出大对象:

3、释放空间

4、把修改强制推送到远端

搞定

如果不小心commit了一个不需要commit的文件,可以对其进行撤销。

 

先使用git log 查看 commit日志

commit 422bc088a7d6c5429f1d0760d008d86c505f4abe  

Author: zhyq0826 <zhyq0826@gmail.com>  

Date:   Tue Sep 4 18:19:23 2012 +0800  

  

    删除最近搜索数目限制  

  

commit 8da0fd772c3acabd6e21e85287bdcfcfe8e74c85  

Merge: 461ac36 0283074  

Author: zhyq0826 <zhyq0826@gmail.com>  

Date:   Tue Sep 4 18:16:09 2012 +0800

找到需要回退的那次commit的 哈希值,

 

git reset --hard commit_id 

 

 使用上面的命令进行回退

 

以下是豆瓣的

 

苍炎的日记

 

起因: 不小新把记录了公司服务器IP,账号,密码的文件提交到了git

方法:

    git reset --hard <commit_id>

    git push origin HEAD --force

其他:

    根据–soft –mixed –hard,会对working tree和index和HEAD进行重置:

    git reset –mixed:此为默认方式,不带任何参数的git reset,即时这种方式,它回退到某个版本,只保留源码,回退commit和index信息

    git reset –soft:回退到某个版本,只回退了commit的信息,不会恢复到index file一级。如果还要提交,直接commit即可

    git reset –hard:彻底回退到某个版本,本地的源码也会变为上一个版本的内容

    HEAD 最近一个提交

    HEAD^ 上一次

    <commit_id> 每次commit的SHA1值. 可以用git log 看到,也可以在页面上commit标签页里找到


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/tougao/7948339.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-11
下一篇2023-04-11

发表评论

登录后才能评论

评论列表(0条)

    保存