git 多个提交记录合并为一个

1.场景

有时候用devops等平台测试问题,需要多次修改小的记录提交,但是最终我们在合并主干的时候不想留那么多乱七八糟的记录,就需要在此分支合并这些提交记录,再合并到主干。

2.交互式变基

2.1 确定要合并的提交范围

复制代码
# 查看最近提交历史
git log --oneline

2.2 启动交互式变基

复制代码
# 合并最近4个提交
git rebase -i HEAD~4

# 或者指定到某个commit
git rebase -i abc1234^

2.3 在编辑器中修改提交指令

复制代码
pick a1b2c3d 第一个提交
squash b2c3d4e 第二个提交
squash c3d4e5f 第三个提交
squash d4e5f6g 第四个提交
  • 保留第一个提交为 pick

  • 将后续要合并的提交改为 squashs (保留提交信息)

  • 或使用 fixupf (丢弃提交信息)

2.4 保存并退出编辑器

在Vim中是:wq

2.5 编辑合并后的提交信息

  • Git会打开一个新编辑器让你编辑最终的提交信息

  • 默认会包含所有被合并提交的信息,你可以修改或保留

2.6 完成合并

  • 保存退出后,多个提交就合并为一个了

2.7 强制推送

如果已经推送到了远程仓库,合并后需要强制推送:

复制代码
git push -f
相关推荐
czhc114007566332 分钟前
6.4:git
git
Rain50938 分钟前
实战:搭建 AI Code Review 自动化流水线
前端·人工智能·git·ci/cd·自动化·ai编程·代码复审
zzzzzz31039 分钟前
GitHub 今日爆火!headroom:一个帮你省 60-95% Token 的 AI Agent 上下文压缩神器
git·机器学习·github
张小凡vip2 小时前
gitlab的ci配置文件yaml参数说明
git·ci/cd·gitlab
搬砖的前端3 小时前
AI工具集:Git提交时使用AI进行CodeReview如何在前端应用构建NPM包
前端·人工智能·git·npm·codeview
ZXF_H3 小时前
Git clone 时遇到fatal: protocol ‘http‘ is not supported问题解决方法
git
傻啦嘿哟3 小时前
日志分析:利用OpenClaw日志排查“403”和“503”错误
java·git·github
摆烂菜鸡沧9964 小时前
【自用记录】修改GitHub提交历史作者
git·github
佳木逢钺13 小时前
Git分支强制覆盖与冲突解决实战记录
git·源代码管理
屋外雨大,惊蛰出没20 小时前
Git基本应用
git