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

深圳做网站的网正邦集团招聘

深圳做网站的网,正邦集团招聘,上海有色金属门户网站,服务器 网站 搬家从Git历史中删除大文件的完整解决方案 当你意外提交了一个大文件导致无法推送到远程仓库时,可以按照以下步骤彻底从Git历史中删除这个大文件。 情况分析 首先确认你的问题属于以下哪种情况: 大文件在最近一次提交中:相对容易处理大文件在…

从Git历史中删除大文件的完整解决方案

当你意外提交了一个大文件导致无法推送到远程仓库时,可以按照以下步骤彻底从Git历史中删除这个大文件。

情况分析

首先确认你的问题属于以下哪种情况:

  1. 大文件在最近一次提交中:相对容易处理
  2. 大文件在较早的提交中:需要重写历史
  3. 大文件已在远程仓库:需要协调团队处理

解决方案

方案一:大文件在最近一次提交(未推送)

# 1. 从最新提交中移除文件但保留在本地
git rm --cached <大文件路径>
# 2. 提交这个更改
git commit --amend
# 3. 确保.gitignore中添加该文件避免再次提交
echo "<大文件路径>" >> .gitignore
git add .gitignore
git commit -m "添加.gitignore忽略大文件"

方案二:大文件在多个历史提交中(需要重写历史)

# 1. 使用BFG Repo-Cleaner(推荐)
# 先下载bfg.jar
java -jar bfg.jar --delete-files <文件名> --no-blob-protection .# 或使用git filter-branch(Git内置)
git filter-branch --force --index-filter \
"git rm --cached --ignore-unmatch <大文件路径>" \
--prune-empty --tag-name-filter cat -- --all# 2. 清理本地仓库
rm -rf .git/refs/original/
git reflog expire --expire=now --all
git gc --prune=now --aggressive# 3. 强制推送到远程
git push origin --force --all
git push origin --force --tags

方案三:大文件已推送到远程仓库

# 1. 先按照方案二清理本地历史
# 2. 通知团队成员
# 3. 让所有团队成员执行以下操作:
git fetch origin
git reset --hard origin/<分支名>

详细步骤说明

步骤1:识别大文件

# 查看仓库中最大的文件
git verify-pack -v .git/objects/pack/*.idx | sort -k 3 -n | tail -5# 或使用更直观的工具
git ls-tree -r -t -l --full-name HEAD | sort -n -k 4 | tail -10

步骤2:使用BFG工具(推荐)

  1. 下载BFG工具:

    wget https://repo1.maven.org/maven2/com/madgag/bfg/1.14.0/bfg-1.14.0.jar
    
  2. 运行清理:

    java -jar bfg-1.14.0.jar --delete-files <文件名> --no-blob-protection .
    
  3. 清理后操作:

    git reflog expire --expire=now --all
    git gc --prune=now --aggressive
    

步骤3:处理.gitignore

确保未来不会再次提交:

echo "<文件或文件模式>" >> .gitignore
git add .gitignore
git commit -m "更新.gitignore文件"

注意事项

  1. 重写历史的风险

    • 如果其他人已经基于这些提交工作,会导致严重问题
    • 只应在个人分支或协调团队后操作
  2. 备份重要数据

    git bundle create backup.bundle --all
    
  3. 替代方案

    • 使用Git LFS管理大文件(如果确实需要版本控制)
    git lfs track "<文件模式>"
    git add .gitattributes
    
  4. 仓库瘦身

    git repack -a -d --depth=250 --window=250
    

验证结果

# 检查仓库大小
git count-objects -vH# 确认文件已从历史中删除
git log --all --find-object=<文件哈希>

完成这些操作后,你的仓库应该可以正常推送到远程了。记得通知团队成员他们需要重新克隆仓库或按照方案三中的步骤重置他们的本地分支。

http://www.dtcms.com/a/484481.html

相关文章:

  • 家庭带宽100m做网站用什么网站做ppt
  • 创意广告视频网站聊城网站seo
  • 网站云空间和普通空间如何做网站详细步骤
  • 保山市住房和城乡建设局门户网站网页设计与网站建设文档
  • 从零起步学习MySQL || 第三章:DML语句定义及常见用法示例
  • 建站公司外包wordpress json 时间
  • php网站开发招招聘网页美工设计实训心得
  • 电子商务网站建设外包服务怎样登录韵网网站
  • 单页营销网站模板无锡app制作
  • seo蒙牛伊利企业网站专业性诊断成都小程序商城开发
  • 万户网站协作管理系统wordpress首页修改路径
  • 免费自助网站用户浏览网站的方式
  • 网站建设购物商城wordpress 咨询主题
  • WordPress强制更换主题佛山seo关键词
  • 如果做网站网站开发技术及特点
  • 齐齐哈尔哪里做网站外贸网站推广建设
  • 服务网站建设方案网络seo哈尔滨
  • 学网站建设语言资料管理系统
  • Bootstrap4 表格详解
  • 网站搜索不到公司网站凡科建站官网登录入口网页版
  • 创建网站app怎么注册中文域名
  • 织梦网站源文件没有style文件夹怎么修改网站背景wordpress 旅游足迹插件
  • 网站制作模板过程网页特效大全
  • 学校网站建设企业直播软件开发需要多少钱
  • 关于网站开发人员的薪资谢家华做网站
  • 基于springboot针对老年人的景区订票系统
  • 越秀区建网站公司如何做公司自己的网站
  • 网站建设网上商城心得体会九江市seo
  • 茂名做网站建设公司单页面网站有哪些内容
  • 京东联盟怎么做CMS网站wordpress国内博客主题