最近碰到个很难办的问题,无意中发现项目文件夹已经快1G了。。。

仔细一看,原来是.git文件夹占了80%。。。

思前想后也找不到原因,最后还是google了半天才找到问题:

之前为了方便把一个200M左右的sdk直接添加到了项目里,然后提交到git上了,更可怕的是sdk还换了好几个版本提交了好多次。。。

所以git中就有N多这个sdk修改的记录,占了很大空间;

为什么会出现这种情况呢,就是因为git的存储方式

git仓库下有一个名为 .git 的隐藏文件夹 ,从git初始化(git init)开始,所有仓库的变化都会记录在这个.git文件夹中;只要是git记录的文件(add 并且 commit),就会通过一定的算法保存到这里,

删除一个文件,只是记录了删除这个操作,但并不会把文件从.git文件夹删除。

所以直接删除项目中的文件,.git文件夹完全不会变小(理论上还会变大一点,因为多记录了一次删除操作。。。)

要想彻底删除git已经记录的文件,就必须用到一个高端命令:git filter-branch

官方解释可以看这里:

具体怎么使用可以参考这两篇博客:

具体到我这儿,因为我添加了 XXX.framework的库,所以命令就是:

git filter-branch --force --prune-empty --index-filter 'git rm -rf --cached --ignore-unmatch XXX.framework' --tag-name-filter cat -- --all

各个参数的意思摘抄如下

filter-branch 是让git重写每一个分支,

--force 假如遇到冲突也让git强制执行,

--index-filter 选项指定重写的时候应该执行什么命令,要执行的命令紧跟在它的后面,在这里就是git rm --cached --ignore-unmatch password.txt ,让git删除掉缓存的文件,如果有匹配的话。

--prune-empty 选项告诉git,如果因为重写导致某些commit变成了空(比如修改的文件全部被删除),那么忽略掉这个commit。

--tag-name-filter 表示对每一个tag如何重命名,重命名的命令紧跟在后面,当前的tag名会从标注输入送给后面的命令,用cat就表示保持tag名不变。

紧跟着的-- 表示分割符,

最后的--all 表示对所有的文件都考虑在内。

等命令执行完了,要提交到远程再

git push --force --all

就可以了

在实际操作中,我还遇到点其他问题,一并记录下来~

因为XXX.framework其实是个文件夹,所以在 rm 命令之后必须 加上 -rf 参数,不然其实会漏删不少东西

命令里面的 --all 似乎不怎么管用,至少对分支是不管用的,(博客1里面说是对所有分支。。。貌似有点问题)

一开始我项目有好几个分支,我直接在master上操作,完了之后push,结果.git文件夹确实有变小,但变小的很有限。。。

后来我把其他的分支备份出来,然后删掉项目里的所有分支,只剩下master,再来了一遍,果然就可以了,远程仓库果然变小了超级多

本地的.git文件夹依然没啥变化,这是因为有很多本地缓存,重新git clone远程就好了

git push --force --all其实也是个很危险的操作 ,再执行这个之前,务必确保当前代码已经是最新,并且你开始操作后没有人提交过代码,

不然这么一force,有一大片冲突是必然的。。。不说了,说多了都是泪。。。

教训:

sdk之类的大文件,尽量不要直接添加到git中,如果sdk不经常更新且不太大(多大算大多大算小看各自网速了),那直接添加进去问题也不大;

如果sdk比较大或者经常更新,那就真的注意不能玩git里面加了,目前想到的比较好的替代方案有:

把sdk写到.gitignore中,在readme等地方写清楚,项目用到了什么sdk,让用的人自己去下载;

这个方法比较容易实现,不过对用的人来说不太友好。毕竟除了直接复制粘贴,直接git clone的代码是不能直接用的。。。

用pod来管理

一般来说pods是不会放到git里面的,都是用的时候再pod install;所以可以给项目用到的sdk之类的大文件,专门建一个pod库,让项目通过pod依赖这些大文件。

这也是我现在用的方案,效果还是很不错的~

再加上pod还可以配置一些依赖库(方法可以参考https://github.com/Phelthas/LXMThirdLoginManager ,关键是.podspec文件),那就更加方便了!强烈推荐!!!

有什么问题,欢迎讨论~

git里面的文件怎么删不掉_彻底删除git中没用的大文件相关推荐

  1. Java自带的广告怎么删掉_怎样删除电脑中的广告

    展开全部 如何删除讨厌62616964757a686964616fe4b893e5b19e31333433636130的广告和安装的其它程序 当我们安装一些软件时,它们捆绑安装了一些我们不需要的广告或 ...

  2. linux删除中文名文件,linux运维 - linux下 怎样删除文件名中包含特殊字符的文件...

    目录中无意间出现了 -- 这个文件 [root@dev tmp]# ls -- 00 01 02 03 04 05 06 07 08 09 [root@dev tmp]# ll total 0 -rw ...

  3. 遇见流氓软件怎么才能卸载,文件夹删不掉显示被占用(小鸟,海螺,原始传奇等),到底应该怎么办?

    遇见流氓软件怎么才能卸载,文件夹删不掉显示被占用(小鸟,海螺,原始传奇等) 首先,描述一下我遇见流氓软件的过程,最开始我想下一个音乐播放器,选择了网易云音乐,在谷歌浏览器上搜索了网易云官方下载,但是并 ...

  4. 服务器c盘有个inetpub文件夹,Win10正式版C盘inetpub文件夹可以删除吗 Win10正式版C盘inetpub文件夹删不掉怎么办...

    类型:远程监控大小:4.6M语言:中文 评分:5.7 标签: 立即下载 最近不少朋友都进行了win10正式版的升级安装,不过不少细心的朋友发现,自己升级安装了win10后c盘里多了一个inetpub文 ...

  5. 服务器C盘中的文件删不掉,小编面对win10系统C盘inetpub文件夹删不掉的处理步骤...

    许多win10系统用户在工作中经常会遇到win10系统C盘inetpub文件夹删不掉的情况,比如近日有用户到本站反映说win10系统C盘inetpub文件夹删不掉的问题,但是却不知道要怎么解决win1 ...

  6. 服务器c盘有个inetpub文件夹,老司机为你示范win10系统C盘inetpub文件夹删不掉的图文教程...

    也许大家在用电脑工作的使用中会遇到win10系统C盘inetpub文件夹删不掉的情况,目前就有很多朋友向我资讯关于win10系统C盘inetpub文件夹删不掉的具体处理步骤.小编把总结的关于win10 ...

  7. 计算机里面的文件一直和桌面上重复,有些文件删不掉_电脑桌面上有一个文件图标老是删不掉,每次删,都......

    为什么桌面上有些文件删不掉 在电脑删除文件时为什么有些文件删不了? ①首先找到拒绝访问的文件夹,在其上鼠标右键,选择属性,之后切换到安全选项下,之后在底部可以看到有高级设置入后, ②首先点击底部的高级 ...

  8. 如何删除tmp计算机桌面,桌面上的文件删不掉_我桌面上突然多了一个tmp结尾的文件桌面删除都删除......

    桌面上的文件 删不掉怎么办 为什么桌面上有些文件删不掉 我电脑桌面上有个文件夹,删除不掉怎么办? 我的电脑桌面上文件夹删不掉 解决我的电脑桌面上文件夹删不掉的步骤如下: 1.首先在我们的电脑桌面上找到 ...

  9. 显示文件已在其他地方打开,文件始终删不掉怎么办【简单安全高效的解决办法!】

    问题: 显示文件已在其他地方打开,可是发现没打开啥相关程序啊,文件始终删不掉怎么办?重启电脑后再删除也没用咋办?更改操作改文件的权限后还是无法删除咋办? 解决: 1,将该文件重命名(随便命名) 2,重 ...

  10. 百度云管家在计算机上删除,百度云管家盘符删不掉怎么办?删除百度云管家盘符的方法...

    选择很多的人都喜欢使用百度云盘来进行文件或者的资料的存放,为的就是在其它的地方也能将文件或资料实施开启,就不用再使用硬盘或者是U盘来进行携带,这样不仅减少了很多不必要的麻烦,而且还简单轻松.然我们在使 ...

最新文章

  1. JS Array 中 shift 和 pop 的妙用
  2. 爬虫-selenium初步学习与使用!
  3. 一份来自大厂算法工程师的求职宝典
  4. 内存地址 哪个程序_记一次排查线上程序内存的忽高忽低,又是大集合惹祸了...
  5. 前端CSS基础7.8
  6. 2.2.2 指数加权平均
  7. Dapr集成之GRPC 接口
  8. 保驾护航金三银四,分分钟搞定!
  9. 经典中的博弈:第一章 C++的Hello,World!
  10. 原创:CAD批量去除教育版戳记
  11. 怎么减小照片大小kb?
  12. android转移数据到苹果手机号码,苹果电话号码怎么转到新手机(简单教你两招轻松搞定)...
  13. 概率论基础 - 6 - 切比雪夫不等式
  14. 服务器通过ilo安装系统,如何通过ilo开启服务器远程桌面
  15. linux下ad键盘驱动,led、键盘、ADC驱动程序
  16. 生物信息学必备网站大全
  17. MySQL数据库-错误1166 Incorrect column name
  18. android更换开机动画,修改安卓开机动画(除了部分系统 如MIUI等)
  19. Springboot使用Specification连表查询LEFT
  20. B站狂神 JavaWeb 1-6

热门文章

  1. 牛牛卡牌游戏 javascript
  2. 10种防止网络被攻击的方法
  3. Wet-Ra: Monitoring Diapers Wetness with Wireless Signals
  4. FDD与TDD工作原理
  5. MSP430F5529 入门心得
  6. PS——图像合成与渐变工具
  7. 安装算量软件使用_鹏业安装算量软件常用按钮汇总(三)
  8. 秋招历险记-计算机网络篇
  9. js实现网页在线聊天功能(一)
  10. 双线路接入(双网卡)