轉(zhuǎn)自:http://www.cnblogs.com/qmmq/p/4604862.html
同樣是記錄一下自己工作遇到的問題,免得下次再遇到了還到處網(wǎng)上查資料解決。
自己的項目的版本控制用的是Git,代碼倉庫在github托管缩功。項目里用到了百度導(dǎo)航SDK层扶,由于百度導(dǎo)航SDK有了新版本箫章,于是就更新到了新版本,更新好了之后想把代碼push到github上镜会,結(jié)果出錯了檬寂,被拒絕,具體信息是:Total 3007 (delta 664), reused 0 (delta 0)
remote: error: GH001: Large files detected.
remote: error: Trace: 7b7de6b9372ee392e0f3961b05ea6f33
remote: error: See http://git.io/iEPt8g for more information.
remote: error: File? XXX/XXX/BaiduNaviSDK/libbaiduNaviSDK.a is 102.68 MB; this exceeds GitHub's file size limit of 100.00 MB
To https://github.com/XXX/XXXX.git戳表。意思是有大文件桶至,更多信息可到http://git.io/iEPt8g查看,文件libbaiduNaviSDK.a的大小超過了GitHub限制的100M大小匾旭。想要push镣屹,必須把這個文件移除,可是要怎么移除呢价涝?開始我是想著直接刪除掉libbaiduNaviSDK.a女蜈,結(jié)果不行,還是會報上面的錯色瘩,于是我又把libbaiduNaviSDK.a放到忽略文件里伪窖,結(jié)果還是不行,還是說有大文件居兆,報同樣的錯惰许。這下只能老老實實的看官方的解決辦法了,于是就打開http://git.io/iEPt8g老老實實的研究了一番史辙。大意是說為了便于管理代碼庫和方便合作伙伴們使用汹买,當(dāng)你push50M以上的文件時github將會警告,當(dāng)push100M以上文件聊倔,就直接拒絕你的push晦毙,要想push必須把該文件從本地倉庫和遠(yuǎn)程倉庫全部移除掉。這個移除會永久性的從本地git和github里移除耙蔑,如果這個文件很重要见妒,要記得做一次備份。下面進(jìn)入具體操作甸陌。如果這個文件是最近一次commit的须揣,并且你還沒有push到github,那么第一步輸入命令 cd /Users/Dora/Desktop/XXX(cd后面的這個路徑要換成你自己項目的路徑)钱豁,然后第二步輸入命令 git rm --cached/Users/Dora/Desktop/XXX/XXX/libbaiduNaviSDK.a(加下劃線部分是你自己的要移除的文件的路徑)耻卡,第三步輸入命令 git commit --amend -CHEAD,執(zhí)行完這步后牲尺,這個大文件將會從你的commit記錄里移除卵酪,并且以后commit都將不會再把它commit了幌蚊,這時候就可以git push把本地代碼push到github上了。
注意:這里可能遇到輸入git rm --cached/Users/Dora/Desktop/XXX/XXX/libbaiduNaviSDK.a命令后說找不到你要刪除的文件的問題溃卡,出現(xiàn)這個問題的原因是你要刪除的文件路徑名沒寫對溢豆,一定要仔細(xì)檢查,確保要刪除的文件的路徑是正確的瘸羡。
如果做了這幾步你push的時候還是報和開始的時候一樣的錯漩仙,那說明這個文件你不是最近一次commit時添加的,而是在之前commit過很多次了犹赖,這就需要把關(guān)于這個文件的所有歷史commit記錄全部清除掉讯赏,這時候我們就需要用到一個叫BFG的工具。我們要到https://rtyley.github.io/bfg-repo-cleaner/#download這個網(wǎng)站去下載并學(xué)習(xí)如何使用這個工具冷尉。首先先得把這個軟件下載下來漱挎,雙擊它,如果你的電腦沒有java的SDK雀哨,按照提示安裝好磕谅,否則BFG將運行不了。好了之后雾棺,我們要cd進(jìn)BFG文件所在目錄膊夹,第一步輸入命令java -jarbfg.jar--no-blob-protection--strip-blobs-bigger-than50Mmy-repo.git(紅色部分是你下載下來的文件的名字,藍(lán)色部分是你需要移除的文件大小,橙色部分是你自己.git文件的路徑)捌浩,第二步cdmy-repo.git放刨,第三步git reflog expire --expire=now --all && git gc --prune=now --aggressive,第四步git push尸饺,到此大功告成进统。你的commit歷史里所有大于50M的文件的commit全部被清除,這樣你就可以push到github上了浪听。這里只是記錄了怎么處理遇到的問題螟碎,如果想要知道原理,則需要好好好去學(xué)習(xí)學(xué)習(xí)迹栓。
注意:這里可能遇到輸入命令java -jarbfg.jar--strip-blobs-bigger-than50Mmy-repo.git后bfg運行不成功的問題掉分,原因是java -jar bfg.jar這個命令必須要在bfg.jar所在目錄下運行才行,否則系統(tǒng)將不知道bfg.jar文件在哪里克伊,所以執(zhí)行不成功酥郭。所以我們要先cd到bfg.jar所在目錄,然后在執(zhí)行ava -jarbfg.jar--strip-blobs-bigger-than50Mmy-repo.git命令愿吹。對于不熟悉命令行的人來說最容易犯這些錯誤了不从。