前言
之前写过一篇关于github的文章:https://www.jianshu.com/p/9613b345f3cf
在这篇文章中我用来演示的是一张图片,图片很小不会触发100M限制的问题,但是后来我要集成ijkplayer
完成一个直播功能,这个项目中IJKMediaFramework.framework/IJKMediaFramework
文件有111.22 MB,push
代码遇到了问题:
remote: error: GH001: Large files detected. You may want to try Git Large File Storage - https://git-lfs.github.com.
remote: error: Trace: a7e4d1fcd51b218966318a602e9ef861
remote: error: See http://git.io/iEPt8g for more information.
remote: error: File IJKMediaFramework.framework/IJKMediaFramework is 111.22 MB; this exceeds GitHub's file size limit of 100.00 MB
To github.com:jzglovewjr/ijkplayer.git
! [remote rejected] master -> master (pre-receive hook declined)
error: failed to push some refs to 'git@github.com:xxxxxx/ijkplayer.git'
有的人说这是因为权限问题引起的,我查了好多文章按照流程也没有解决,后来使用LFS解决了这个问题。本来想着将这一篇放到上一篇文章中,但是后来一想那篇文章写的又臭又长😂,而这一部分耽误了我不少时间,所以单开一篇文章加以介绍。
LFS 简介与集成
LFS (Large File Storage)顾名思义是git
中的一个大文件存储的一个工具
当然,LFS 并不能像"变魔术一样"处理所有的大型数据:它需要记录并保存每一个变化。然而,这就把负担转移给了远程服务器 - 允许本地仓库保持相对的精简。
为了实现这个可能,LFS 耍了一个小把戏:它在本地仓库中并不保留所有的文件版本,而是仅根据需要提供检出版本中必需的文件。
但这引发了一个有意思的问题:如果这些庞大的文件本身没有出现在你的本地仓库中....改用什么来代替呢? LFS 保存轻量级指针中有真实的文件数据。当你用一个这样的指针去迁出一个修订版时,LFS 会很轻易地找到源文件(不在他上面可能就在服务器上,特殊缓存)然后你下载就行了。
因此,你最终只会得到你真正想要的文件 - 而不是一些你可能永远都不需要冗余数据。
首先查看自己的电脑是不是已经安装了LFS
git-lfs --version
//我的mac已经安装了LFS可以看到
git-lfs/2.5.1 (GitHub; darwin amd64; go 1.10.3)
mac安装homebrew
参照:https://www.jianshu.com/p/65fb80dff4d6
没有安装LFS的mac可以使用homebrew
安装:
brew install git-lfs
安装成功之后还要执行:
git lfs install
没有特别说明的情况下,LFS 不会处理大文件问题,因此,我们必须明确告诉 LFS 该处理哪些文件。
让我们回到
ijkplayer
工程的示例, 我们可以使用lfs track
命令来告诉 LFS 处理IJKMediaFramework.framework/IJKMediaFramework
文件
首先进入clone
到本地的ijk
文件夹可以看到IJKMediaFramework.framework
文件,双击文件可以看到IJKMediaFramework
文件,比较大的是这个IJKMediaFramework
文件,所以las track
命令必须指向IJKMediaFramework.framework/IJKMediaFramework
执行命令:
git lfs track "IJKMediaFramework.framework/IJKMediaFramework"
执行完毕之后就在ijk
根目录中新建了.gitattributes
文件,可能看不到,可以通过cat
命令查看:
cat .gitattributes //查看.gitattributes文件,注意有一个点儿
//可以看到.gitattributes中的内容为
IJKMediaFramework.framework filter=lfs diff=lfs merge=lfs -text
如果之前已经存在.gitattributes
文件也没有关系,他只会修改里面的内容,.gitattributes
文件也是需要提交到服务器的,所以先要执行
git add .gitattributes
git commit -m "add or edit file .gitattributes"
git push -u origin master //选择自己的分支,我是在master分支直接编辑的
提交成功之后再提交其他文件:
git add . //注意这个点儿啊,表示添加所有文件
git commit -m "add project ijkplayer" -a
git push -u origin master //选择自己的分支,我是在master分支直接编辑的
稍等一会儿可以看到:
大功告成😄
参考文章
https://www.oschina.net/translate/getting-started-with-git-lfs-tutorial
https://www.atlassian.com/git/tutorials/git-lfs#moving-between-hosts
https://github.com/git-lfs/git-lfs/issues/1328