記錄一下自己工作遇到的問題竖慧,免得下次再遇到了還到處網(wǎng)上查資料解決嫌套。
自己的項(xiàng)目的版本控制用的是Git,代碼倉庫在github托管圾旨。項(xiàng)目里用到了百度導(dǎo)航SDK踱讨,由于百度導(dǎo)航SDK有了新版本,于是就更新到了新版本砍的,更新好了之后想把代碼push到github上痹筛,結(jié)果出錯(cuò)了,被拒絕廓鞠,具體信息是: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: FileXXX/XXX/BaiduNaviSDK/libbaiduNaviSDK.a is 102.68 MB; this exceeds GitHub's file size limit of 100.00 MBTo https://github.com/XXX/XXXX.git帚稠。
意思是有大文件,更多信息可到http://git.io/iEPt8g查看床佳,文件libbaiduNaviSDK.a的大小超過了GitHub限制的100M大小滋早。想要push,必須把這個(gè)文件移除砌们,可是要怎么移除呢杆麸?開始我是想著直接刪除掉libbaiduNaviSDK.a搁进,結(jié)果不行,還是會(huì)報(bào)上面的錯(cuò)昔头,于是我又把libbaiduNaviSDK.a放到忽略文件里拷获,結(jié)果還是不行,還是說有大文件减细,報(bào)同樣的錯(cuò)匆瓜。這下只能老老實(shí)實(shí)的看官方的解決辦法了,于是就打開http://git.io/iEPt8g老老實(shí)實(shí)的研究了一番未蝌。大意是說為了便于管理代碼庫和方便合作伙伴們使用驮吱,當(dāng)你push50M以上的文件時(shí)github將會(huì)警告,當(dāng)push100M以上文件萧吠,就直接拒絕你的push左冬,要想push必須把該文件從本地倉庫和遠(yuǎn)程倉庫全部移除掉。這個(gè)移除會(huì)永久性的從本地git和github里移除纸型,如果這個(gè)文件很重要拇砰,要記得做一次備份。下面進(jìn)入具體操作狰腌。如果這個(gè)文件是最近一次commit的除破,并且你還沒有push到github,那么第一步輸入命令 cd /Users/Dora/Desktop/XXX(cd后面的這個(gè)路徑要換成你自己項(xiàng)目的路徑)琼腔,然后第二步輸入命令 git rm --cached/Users/Dora/Desktop/XXX/XXX/libbaiduNaviSDK.a(加下劃線部分是你自己的要移除的文件的路徑)瑰枫,第三步輸入命令 git commit --amend -CHEAD,執(zhí)行完這步后丹莲,這個(gè)大文件將會(huì)從你的commit記錄里移除光坝,并且以后commit都將不會(huì)再把它c(diǎn)ommit了,這時(shí)候就可以git push把本地代碼push到github上了甥材。
注意:這里可能遇到輸入git rm --cached/Users/Dora/Desktop/XXX/XXX/libbaiduNaviSDK.a命令后說找不到你要?jiǎng)h除的文件的問題盯另,出現(xiàn)這個(gè)問題的原因是你要?jiǎng)h除的文件路徑名沒寫對,一定要仔細(xì)檢查洲赵,確保要?jiǎng)h除的文件的路徑是正確的鸳惯。
如果做了這幾步你push的時(shí)候還是報(bào)和開始的時(shí)候一樣的錯(cuò),那說明這個(gè)文件你不是最近一次commit時(shí)添加的板鬓,而是在之前commit過很多次了悲敷,這就需要把關(guān)于這個(gè)文件的所有歷史commit記錄全部清除掉,這時(shí)候我們就需要用到一個(gè)叫BFG的工具俭令。我們要到https://rtyley.github.io/bfg-repo-cleaner/#download這個(gè)網(wǎng)站去下載并學(xué)習(xí)如何使用這個(gè)工具后德。首先先得把這個(gè)軟件下載下來,雙擊它抄腔,如果你的電腦沒有java的SDK瓢湃,按照提示安裝好理张,否則BFG將運(yùn)行不了。好了之后绵患,我們要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運(yùn)行不成功的問題荡陷,原因是java -jar bfg.jar這個(gè)命令必須要在bfg.jar所在目錄下運(yùn)行才行,否則系統(tǒng)將不知道bfg.jar文件在哪里迅涮,所以執(zhí)行不成功废赞。所以我們要先cd到bfg.jar所在目錄,然后在執(zhí)行ava -jarbfg.jar--strip-blobs-bigger-than50Mmy-repo.git命令逗柴。對于不熟悉命令行的人來說最容易犯這些錯(cuò)誤了蛹头。