【软件工程】如何使用Git Rebase同步团队开发进度

问题背景

现在,我正在我本地的私人开发分支feat/wu-sunflower/do_some_thing(对应云端分支origin/feat/wu-sunflower/do_some_thing),进行开发。

同时我的同事对代码也进行了一些改动(并且已经merge进了团队云端分支origin/dev)。我应该如何通过git rebase,与我的同事同步开发进度?

步骤

步骤 1:确保工作目录干净

检查工作目录中是否有未commit的修改。

bash 复制代码
git switch feat/wu-sunflower/do_some_thing  # 切换到我的分支
git status

如果有,请先commit,或者执行git stash把这些变动临时藏匿起来。

bash 复制代码
# 1. 正在开发中,修改了文件 A 和 B(未提交)
git status  # 显示有修改
# 2. 需要拉取团队最新代码
git stash -m "开发到一半的功能 A"
# 3. 现在工作目录干净了,可以拉取代码
git pull origin dev
# 4. 恢复之前的修改
git stash pop  # 或 git stash apply
# 5. 如果有冲突,手动解决后继续开发

步骤 2:拉取团队最新代码(不自动合并)

bash 复制代码
git fetch origin dev # 获取云端 dev 分支的最新提交

步骤 3:变基(rebase)我的分支到最新 dev

bash 复制代码
git rebase origin/dev  # 将当前分支变基到 origin/dev

此时可能出现冲突(因我的修改和同事的修改冲突)。

步骤 4:解决冲突(如果有)

定位冲突文件:

bash 复制代码
git status  # 查看冲突文件列表

然后手动编辑文件,解决冲突(文件中的 <<<<<<<>>>>>>> 标记区域)。

之后手工告知git,冲突已解决:

bash 复制代码
git add <冲突文件路径>  # 将解决后的文件加入暂存区

继续变基:

bash 复制代码
git rebase --continue

重复此过程直到所有冲突解决。

若需放弃变基:

bash 复制代码
git rebase --abort  # 回到 rebase 前的状态

步骤 5:推送更新到我的云端分支

shell 复制代码
git push origin feat/wu-sunflower/do_some_thing --force-with-lease

此操作将把变基后的本地仓库推送到云端分支origin/feat/wu-sunflower/do_some_thing

最终效果

css 复制代码
我的原始提交:          A--B--C [feat/wu-sunflower/...]
团队 dev 更新:         D--E--F [origin/dev]
变基后:                D--E--F--A'--B'--C' [feat/wu-sunflower/...]

A', B', C' 是我的提交在最新 dev 上的重新应用)

相关推荐
吴声子夜歌12 分钟前
TypeScript——泛型
前端·git·typescript
春日见1 小时前
3三分彻底了解Git Graph极其应用
git
东离与糖宝1 小时前
金三银四Java校招面经:从双非到大厂Offer,我只准备了这些
java·面试
红云梦2 小时前
简历投了 100 份没回音?我给面试平台加了个“简历雷达“
人工智能·面试·职场和发展
风.foxwho2 小时前
jenkins使用 ED25519密钥 拉取Git 代码 配置
git·servlet·jenkins
星辰_mya3 小时前
InnoDB的“身体结构”:页、Buffer Pool与Redo Log的底层奥秘
数据库·mysql·spring·面试·系统架构
iPadiPhone3 小时前
分布式架构的“润滑剂”:RabbitMQ 核心原理与大厂面试避坑指南
分布式·后端·面试·架构·rabbitmq
kyriewen3 小时前
DOM树与节点操作:用JS给网页“动手术”
前端·javascript·面试
郝学胜-神的一滴3 小时前
【技术实战】500G单行大文件读取难题破解!生成器+自定义函数最优方案解析
开发语言·python·程序人生·面试
ruanCat3 小时前
前端工程化工具链从零配置:simple-git-hooks + lint-staged + commitlint
前端·git·代码规范