遇到的问题
今天在提交的代码时遇到提交失败的问题,经过测试发现提交较少的文件没有问题,提交的改动比较大的时候就会出现报错,所以基本排除git权限导致的问题。
报错信息如下:
error: RPC failed; HTTP 413 curl 22 The requested URL returned error:413
fatal: The remote end hung up unexpectedly
fatal: The remote end hung up unexpectedly
原因分析
经查找相关资料得知可能有如下几个原因:
- 提交的文件太大,http缓冲区大小不够,导致push失败。
- 提交的改动过多,导致本地的暂存区占用太大。
- git服务器做了限制,限制了上传文件的大小。
解决办法
- 第一种原因是最常见的,http的postBuffer不够大,一般将其修改为500M(500*1024*1024=524288000)后即可解决:
git config http.postBuffer 524288000
如上配置只对当前仓库有效,如果想全局生效, 添加–global参数即可。
git config --global http.postBuffer 524288000
- 第二种原因比较少见,主要原因是由于有比较多的零散文件提交或删除导致的,我们可以在提交代码前先运行垃圾回收(garbage collect)命令,给git仓库瘦身来解决这个问题:
git gc --aggressive --prune=now
该命令会收集所有松散对象并将它们存入 packfile,合并这些 packfile 进一个大的 packfile,然后将不被任何 commit 引用并且已存在一段时间 (数月) 的对象删除。(也就是会删除掉一部分历史记录,要慎用,如果不是仓库实在太大了,没必要执行该命令)
- 如果是第三种原因导致的,需要联系服务器后台管理员修改限制值,或分多次提交。