当前位置:首页 > 技术分析 > 正文内容

同事git push到主分支上了,技术总监怒了

ruisui883个月前 (03-04)技术分析18

事情是这样的,同事前几天提交使用git提交代码的时候不小心提交到主分支上了,关键还提交成功了,这可是他自己开发的模块,还没测试的呢。技术总监也知道了,这下他慌乱了。最后还是技术总监给他兜底了。

为了防止以后出现git push到主分支,所以写了这篇文章记录一下。

防止 git push 到主分支上

为了防止不小心将代码 push 到主分支(如 mainmaster),可以采取以下几种方法:

1. 使用 Git 钩子(Git Hooks)

示例代码: 在项目的 .git/hooks 目录下创建一个名为 pre-push 的文件,并添加以下内容:

#!/bin/sh

# 获取要推送的分支名
branch=$(git symbolic-ref --short HEAD)

# 如果当前分支是 main 或 master,则阻止推送
if [ "$branch" = "main" ] || [ "$branch" = "master" ]; then
  echo "Error: Cannot push to $branch branch."
  exit 1
fi

然后,给该文件添加执行权限:

chmod +x .git/hooks/pre-push

这样,在执行 git push 时,如果当前分支是 mainmaster,就会触发钩子脚本,阻止推送操作。

2. 配置 Git 仓库的分支保护规则

如果你使用的是 GitHub、GitLab 等远程 Git 仓库托管服务,可以在仓库设置中配置分支保护规则,禁止直接推送代码到主分支。

以 GitHub 为例:

  1. 登录 GitHub,进入你的仓库页面。
  2. 点击仓库设置中的 "Settings" 选项卡。
  3. 在左侧菜单中选择 "Branches"。
  4. 在 "Branch protection rules" 部分,点击 "Add branch protection rule"。
  5. 输入要保护的分支名称(如 mainmaster),勾选 "Protect matching branches" 选项,然后在 "Rules" 部分勾选 "Require pull request reviews before merging" 选项。
  6. 点击 "Create" 按钮保存设置。

这样,只有通过合并请求(Pull Request)并经过审查后,才能将代码合并到主分支。

Git 分支在工作中的常用应用

1. 特性开发分支(Feature Branch)

  • 场景:开发新功能或特性时。
  • 操作流程
  • 从主分支(如 mainmaster)创建一个新的特性分支:
git checkout -b feature/new-feature
  • 在特性分支上进行开发,提交代码:
git add .
git commit -m "Add new feature"
  • 开发完成后,切换回主分支:
git checkout main
  • 将特性分支合并到主分支:
git merge feature/new-feature
  • 删除特性分支:
git branch -d feature/new-feature

2. 修复分支(Bugfix Branch)

  • 场景:修复主分支上的 Bug 时。
  • 操作流程
  • 从主分支创建一个修复分支:
git checkout -b bugfix/fix-bug
  • 在修复分支上定位并修复 Bug,提交代码:
git add .
git commit -m "Fix bug"
  • 切换回主分支:
git checkout main
  • 将修复分支合并到主分支:
git merge bugfix/fix-bug
  • 删除修复分支:
git branch -d bugfix/fix-bug

3. 发布分支(Release Branch)

  • 场景:准备发布新版本时。
  • 操作流程
  • 从主分支创建一个发布分支:
git checkout -b release/v1.0.0
  • 在发布分支上进行版本相关的调整,如更新版本号、修改文档等:
git add .
git commit -m "Prepare for release v1.0.0"
  • 发布完成后,将发布分支合并到主分支和开发分支(如 develop):
git checkout main
git merge release/v1.0.0
git checkout develop
git merge release/v1.0.0
  • 删除发布分支:
git branch -d release/v1.0.0

4. 热修复分支(Hotfix Branch)

  • 场景:在已发布版本中发现严重 Bug,需要紧急修复时。
  • 操作流程
  • 从主分支创建一个热修复分支:
git checkout -b hotfix/fix-critical-bug
  • 在热修复分支上快速修复 Bug,提交代码:
git add .
git commit -m "Fix critical bug"
  • 切换回主分支:
git checkout main
  • 将热修复分支合并到主分支:
git merge hotfix/fix-critical-bug
  • 如果有开发分支(如 develop),也要将热修复分支合并到开发分支:
git checkout develop
git merge hotfix/fix-critical-bug
  • 删除热修复分支:
git branch -d hotfix/fix-critical-bug

5. 开发分支(Develop Branch)

  • 场景:作为日常开发的主要分支,用于集成多个特性分支的代码。
  • 操作流程
  • 从主分支创建开发分支:
git checkout -b develop
  • 在开发分支上集成特性分支、修复分支等:
git merge feature/new-feature
git merge bugfix/fix-bug
  • 定期将开发分支的代码合并到主分支:
git checkout main
git merge develop

创作不易,如果这篇文章对你有用,欢迎点赞关注加评论哦

小伙伴们在工作中还遇到过其他应用场景吗,欢迎评论区留言讨论哦。

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/2482.html

分享给朋友:

“同事git push到主分支上了,技术总监怒了” 的相关文章

Excel VBA 收费单据打印/一步一步带你设计【收费管理系统】12

本文于2023年6月10日首发于本人同名公众号:Excel活学活用,更多文章案例请搜索关注!☆本期内容概要☆用户窗体设置:收费结算模块设置(7)单据打印大家好,我是冷水泡茶,前几期我们分享了【收费管理系统】的设计,最近一期是(Excel VBA 收费结算模块/一步一步带你设计【收费管理系统】11),...

Vue3 如何实现父子组件传值?

在Vue 3中,要实现父子组件传值效果主要通过props和emit两种机制来实现,下面我们就来详细介绍一下这两种机制。父组件向子组件传值propsprops是Vue组件的一种机制,主要的作用就是实现从父组件向子组件传递数据值,在父组件上通过在子组件标签上定义属性来实现数据属性值的传递,在子组件中通过...

vue 3 学习笔记 (八)——provide 和 inject 用法及原理

在父子组件传递数据时,通常使用的是 props 和 emit,父传子时,使用的是 props,如果是父组件传孙组件时,就需要先传给子组件,子组件再传给孙组件,如果多个子组件或多个孙组件使用时,就需要传很多次,会很麻烦。像这种情况,可以使用 provide 和 inject 解决这种问题,不论组件嵌套...

Git 分支管理策略汇总

最近,团队新入职了一些小伙伴,在开发过程中,他们问我 Git 分支是如何管理的,以及应该怎么提交代码?我大概说了一些规则,但仔细想来,好像也并没有形成一个清晰规范的流程。所以查了一些资料,总结出下面这篇文章,一共包含四种常见的分支管理策略,分享给大家。Git flow在这种模式下,主要维护了两类分支...

HTML5学习笔记三:HTML5语法规则

1.标签要小写2.属性值可加可不加””或”3.可以省略某些标签 html body head tbody4.可以省略某些结束标签 tr td li例:显示效果:5.单标签不用加结束标签img input6.废除的标签font center big7.新添加的标签将在下一HTML5学习笔记中重点阐述。...

vue 开发规范

项目运行指南(#项目运行指南)开发本地环境(#开发本地环境)开发相关插件/工具(#开发相关插件工具)开发规范(#开发规范)vue(#vue)【数据流向】(#数据流向)【慎用全局注册】(#慎用全局注册)【组件名称】(#组件名称)【组件中的 CSS】(#组件中的-css)【统一标签顺序】(#统一标签顺序...