当前位置: 首页 > ai >正文

Git Push 失败:HTTP 413 Request Entity Too Large

Git Push 失败:HTTP 413 Request Entity Too Large 问题排查

在使用 Git 推送包含较大编译产物的项目时,你是否遇到过 HTTP 413 Request Entity Too Large 错误?这通常并不是 Git 的问题,而是 Web 服务器(如 Nginx)拒绝接收大体积请求。本文将通过一个完整案例,演示如何使用 curl 工具验证服务器限制,最终通过宝塔面板修改 Nginx 配置解决问题,实现大文件 Git 推送成功。适用于使用 Gitblit、Gitea 或任何基于 Nginx 部署的私有 Git 服务环境。


一、问题描述

在使用 Git 推送一个包含编译产物的仓库时,推送失败,报错如下:

error: RPC failed; HTTP 413 curl 22 The requested URL returned error: 413
send-pack: unexpected disconnect while reading sideband packet
fatal: the remote end hung up unexpectedly

Git GUI (SourceTree) 中显示:

POST git-receive-pack (287021804 bytes)
error: RPC failed; HTTP 413

在这里插入图片描述


二、初步分析

HTTP 413 代表“请求体过大”,通常是服务端拥有上传大小限制。可能的源有两个:

  • Git 服务本身限制 (Gitblit/Gitea/GitLab)
  • Web 服务器如 Nginx 或 Apache 进行的前置限制

为了确认问题所在,我们进行下面的演示性测试。


三、演示测试: curl 模拟上传

步骤1: 创建大文件 (300MB)

在 PowerShell 中执行:

fsutil file createnew bigfile.test 314572800

步骤2: 使用 curl.exe 模拟 POST 上传

curl.exe -v -X POST http://域名/ -H "Expect:" --data-binary "@bigfile.test"

结果:

HTTP/1.1 413 Request Entity Too Large
Server: nginx

确认限制来自 Nginx,Git 本身无问题。

在这里插入图片描述

步骤3: 创建小文件 (1KB)

fsutil file createnew smallfile.test 1024

重复 curl POST 测试,结果成功,显示 Gitblit 网页内容,证明小文件能正常处理。

在这里插入图片描述


四、解决方案:修改 Nginx 配置 (宝塔面板)

操作步骤

  1. 打开宝塔面板后台 (http://你的IP:8888)

  2. 点击左侧「软件商店」,找到 Nginx

  3. 点击「配置修改」或「配置文件」

  4. 找到 http { 块,加入:

    client_max_body_size 512m;  # 允许最大上传体积为 512MB
    
  5. 保存配置

  6. 回到 Nginx 设置界面,重载配置或重启 Nginx

实际配置示意图

在这里插入图片描述

http {include       mime.types;default_type  application/octet-stream;client_max_body_size 512m;sendfile        on;keepalive_timeout  60;...
}

五、重试 Git 推送

配置重载后,再次执行 Git push,推送包大小达 274MB,已成功,问题解决。

在这里插入图片描述


六、总结与建议

操作步骤结果
curl 模拟上传 bigfile.test报 413,确认 Nginx 限制
curl 上传 smallfile.test成功返回 Gitblit 页面
修改 Nginx 配置重载后 push 成功

建议:

  • 尽量不要推送编译产物 (.dll/.lib/.pdb)
  • 使用 .gitignore或 Git LFS 管理大文件
  • 一旦推送无法成功,优先检查 Nginx/选项配置
http://www.xdnf.cn/news/8952.html

相关文章:

  • Linux输出命令——echo解析
  • 实现安卓端与苹果端互通的方案多种多样,以下是一些主要的方案
  • 离轴全息记录与再现
  • 【Unity3D】将自动生成的脚本包含到C#工程文件中
  • 海量数据查询加速:Presto、Trino、Apache Arrow 实战指南
  • 一台手机怎样实现多IP上网?方法有多种
  • 【前端】使用HTTPS
  • js实现生成随机验证码
  • Spring框架之AOP PointCut切入点底层实现原理
  • 【FFmpeg+SDL】播放音频时,声音正常但是有杂音问题(已解决)
  • 有铜半孔工艺的制造难点与工艺优化
  • 人工智能的能源困境:繁荣与危机并存的未来
  • 深入解析Spring Boot与Kafka集成:构建高效消息驱动应用
  • 塔能科技:化解工厂节能改造难题,开启能耗精准节能
  • 华为云Flexus+DeepSeek征文 | Dify-LLM平台一键部署教程及问题解决指南
  • Python常用高阶函数全面解析:通俗易懂的指南
  • 进行性核上性麻痹护理之道:助力患者舒适生活
  • 题目 3332: 蓝桥杯2025年第十六届省赛真题-最多次数
  • 快递实时查询API开发:物流轨迹地图集成教程
  • 遥感解译项目Land-Cover-Semantic-Segmentation-PyTorch之三制作训练数据
  • 从ETL到实时数据处理:数据流管理的演变与未来趋势
  • 谷歌Veo vs Sora:AI视频生成技术的巅峰对决
  • 5G技术赋能楼宇自控系统,数据传输与指令响应效率双提升
  • Spring Boot + OpenCSV 数据清洗实战:CSV 结构化处理与可视化
  • MQTT-Vue整合
  • Linux_编辑器Vim基本使用
  • 快速解决azure aks aad身份和权限问题
  • Parasoft C++Test软件单元测试_实例讲解(局部静态变量的处理)
  • Ubuntu从0到1搭建监控平台:本地部署到公网访问实战教程Cpolar穿透与Docker部署全过程
  • 云原生微服务devops项目管理英文表述详解