github合并多个commit message以及rebase解决文件冲突

github仓库合并多个commit message

问题描述如下:

第一步:确保自己在对应分支上

比如说现在我要合并issue/108分支的提交记录,使用git log --oneline查看提交记录一共有6次,

bash 复制代码
git log --oneline

第二步:使用rebase功能

bash 复制代码
git rebase -i HEAD~6

将上述内容修改如下,把第二行以后的pick改成s即可

由于vscode默认打开的是nano编辑器,将内容做好修改以后,需要保存文件,保存过程是:

  1. Ctrl + O(不会退出,会提示保存)
  2. Enter(确认保存)
  3. Ctrl + X(退出nano)

第三步:

编辑合并后的Commit Message,保存并退出 nano 后,Git 会弹出另一个编辑窗口,用于编辑最终的 commit message,你会看到所有被 squash 的提交消息,类似:

此时可以修改这些message,比如说我修改为下面这个内容,继续保存并退出文件。

  1. Ctrl + O(不会退出,会提示保存)
  2. Enter(确认保存)
  3. Ctrl + X(退出nano)

第四步:

上一步结束以后界面是

第五步:强制推送即可:

bash 复制代码
git push origin issue/108 --force

github解决rebase文件冲突

issue/18从main分支切出来,但是main分支被别人做了修改,导致issue/18目前和main存在文件冲突,现在使用rebase来解决冲突。

第一步:

git pull最新的main和最新的issue/18分支,成功以后切换到issue/18

bash 复制代码
git checkout main
git pull
git checkout issue/18
git pull

第二步:使用rebase命令,展示出冲突文件

bash 复制代码
git rebase main
git status


第三步:点击冲突文件xmake.lua

比如说我选择接受当前,然后点击右下角的Complete Merge

第四步:根据提示继续rebase

bash 复制代码
git rebase --continue

打印出下面这个界面

第五步:检查rebase是否完成

为了安全起见,我不修改任何提交信息,直接使用Esc,以及:wq保存并且退出,打印出下面这个界面,下面这个git rebase --continue是上一步的,不需要额外再用

这里要注意,如果这一步使用git status会打印出

千万不要理会,千万不要使用git pull,直接强制推送即可,

bash 复制代码
git push origin issue/18 --force
相关推荐
寻月隐君1 小时前
Rust 实战:从零构建一个多线程 Web 服务器
后端·rust·github
草梅友仁2 小时前
草梅 Auth 1.3.0 发布与 GitHub 动态 | 2025 年第 32 周草梅周报
开源·github·ai编程
北'辰3 小时前
DeepSeek智能考试系统智能体
前端·后端·架构·开源·github·deepseek
我是哪吒5 小时前
分布式微服务系统架构第164集:架构懂了就来了解数据库存储扩展千亿读写
后端·面试·github
yeshan9 小时前
使用 iFLOW-CLI GitHub Action 和 Qwen3-Coder 给 GitHub 仓库生成幻灯片风格的文档站点
github·ai编程·掘金·金石计划
用户315063273048713 小时前
使用 Vuepress + GitHub Pages 搭建项目文档(2)- 使用 GitHub Actions 工作流自动部署
前端·github
程序视点1 天前
Visual Studio Code (v1.103) 中 GitHub Copilot 最新更新!
github·github copilot
程序视点1 天前
OpenAI 的最新 AI 模型 GPT-5 现已在 GitHub Models 上提供!
github·github copilot
寻月隐君1 天前
Rust NFT 开发实战:构建生产级的 Pinata IPFS 自动化上传工具
后端·rust·github
用户4099322502121 天前
FastAPI消息持久化与ACK机制:如何确保你的任务永不迷路?
后端·github·trae