完整演示 Git Flow 所有分支的创建与流转过程的 实操命令示例

✅ 假设项目刚初始化,只有 main 分支

✅ 所有操作基于命令行

✅ 模拟一个完整周期:开发 → 发布 → 热修复


🚀 第 0 步:初始化项目(仅有 main)

bash 复制代码
# 创建项目目录
mkdir my-project && cd my-project

# 初始化 Git 仓库
git init

# 创建初始文件并提交(main 分支)
echo "# My Project" > README.md
git add .
git commit -m "chore: initial commit"

# (可选)推送到远程
git remote add origin https://your-gitlab.com/your/repo.git
git push -u origin main

此时只有 main 分支。


🌱 第 1 步:创建 develop 分支(长期存在)

bash 复制代码
# 从 main 创建 develop
git checkout -b develop

# 推送到远程(建立跟踪)
git push -u origin develop

🔔 develop 是所有新功能的集成基地,从此以后 新功能不再直接基于 main 开发


➕ 第 2 步:开发一个新功能(feature 分支)

bash 复制代码
# 从 develop 创建 feature 分支
git checkout develop
git checkout -b feature/user-login

# 模拟开发
echo "Login logic here" > login.js
git add .
git commit -m "feat: implement user login"

# 推送 feature 分支(团队协作时需要)
git push -u origin feature/user-login

🔁 第 3 步:完成功能,合并回 develop

bash 复制代码
# 切换回 develop
git checkout develop

# 合并 feature(使用 --no-ff 保留分支拓扑)
git merge --no-ff feature/user-login -m "Merge feature/user-login into develop"

# 推送 develop
git push origin develop

# 删除本地和远程 feature 分支
git branch -d feature/user-login
git push origin --delete feature/user-login

✅ 此时 develop 包含了新功能,但 main 仍是旧版本。


📦 第 4 步:准备发布 v1.0.0(release 分支)

bash 复制代码
# 从 develop 创建 release 分支
git checkout develop
git checkout -b release/v1.0.0

# 模拟发布前工作:改版本号、写文档、修小 bug
echo "1.0.0" > VERSION
git add .
git commit -m "chore: bump version to 1.0.0"

# 推送 release 分支(可选,便于团队测试)
git push -u origin release/v1.0.0

✅ 第 5 步:完成发布 ------ 合并到 maindevelop

bash 复制代码
# 1. 合并到 main,并打标签
git checkout main
git merge --no-ff release/v1.0.0 -m "Release v1.0.0"
git tag -a v1.0.0 -m "Version 1.0.0"
git push origin main --tags

# 2. 合并回 develop(同步 release 中的修复)
git checkout develop
git merge --no-ff release/v1.0.0 -m "Merge release/v1.0.0 into develop"
git push origin develop

# 3. 删除 release 分支
git branch -d release/v1.0.0
git push origin --delete release/v1.0.0

✅ 现在 main 上有 v1.0.0 标签,develop 也包含了发布期的修改。


🆘 第 6 步:线上发现 Bug,紧急热修复(hotfix)

bash 复制代码
# 从 main(最新稳定版)创建 hotfix 分支
git checkout main
git checkout -b hotfix/v1.0.1

# 修复问题
echo "Fixed critical bug" >> login.js
git add .
git commit -m "fix: resolve login timeout in production"

# 推送 hotfix(可选)
git push -u origin hotfix/v1.0.1

🛠️ 第 7 步:完成热修复 ------ 合并到 maindevelop

bash 复制代码
# 1. 合并到 main,打新标签
git checkout main
git merge --no-ff hotfix/v1.0.1 -m "Hotfix v1.0.1"
git tag -a v1.0.1 -m "Hotfix for login timeout"
git push origin main --tags

# 2. 合并到 develop(避免下次发布时 bug 复现)
git checkout develop
git merge --no-ff hotfix/v1.0.1 -m "Merge hotfix/v1.0.1 into develop"
git push origin develop

# 3. 删除 hotfix 分支
git branch -d hotfix/v1.0.1
git push origin --delete hotfix/v1.0.1

🌳 最终分支状态

分支 状态
main 包含 v1.0.1,生产环境代码
develop 包含 v1.0.1 修复 + 未来新功能的基础
远程无 feature/*release/*hotfix/* 分支(已清理)

🔁 下一轮开发?

重复第 2 步:从 develop 创建新的 feature/xxx,继续迭代!


💡 小贴士

  • 所有合并都使用 --no-ff:保留分支历史,便于追溯。
  • 删除远程分支后,其他成员执行 git fetch --prune 清理本地引用。
  • 可用 git log --oneline --graph --all 查看分支拓扑。

这个完整示例展示了 从零开始,基于 main 构建整个 Git Flow 流程 。你可以复制这些命令在本地实验,加深理解。如果配合 git-flow 工具,步骤会更简洁,但理解底层原理更重要

相关推荐
武子康44 分钟前
大数据-241 离线数仓 - 实战:电商核心交易数据模型与 MySQL 源表设计(订单/商品/品类/店铺/支付)
大数据·后端·mysql
IvanCodes1 小时前
一、消息队列理论基础与Kafka架构价值解析
大数据·后端·kafka
南果梨17 小时前
OpenClaw 完整教程!从安装到使用(官方脚本版)
前端·git·开源
武子康1 天前
大数据-240 离线数仓 - 广告业务 Hive ADS 实战:DataX 将 HDFS 分区表导出到 MySQL
大数据·后端·apache hive
洛森唛2 天前
ElasticSearch查询语句Query String详解:从入门到精通
后端·elasticsearch
Selicens2 天前
git批量删除本地多余分支
前端·git·后端
字节跳动数据平台2 天前
5000 字技术向拆解 | 火山引擎多模态数据湖如何释放模思智能的算法生产力
大数据
武子康2 天前
大数据-239 离线数仓 - 广告业务实战:Flume 导入日志到 HDFS,并完成 Hive ODS/DWD 分层加载
大数据·后端·apache hive
洛森唛3 天前
Elasticsearch DSL 查询语法大全:从入门到精通
后端·elasticsearch
闲云一鹤3 天前
Git LFS 扫盲教程 - 你不会还在用 Git 管理大文件吧?
前端·git·前端工程化