git 远程代码回滚master

2023-05-16

       人总是会有犯错的时候,所以我们的代码有时候就需要回滚。


       当我们要回滚的代码还没有提交到远程的时候,可以进行本地回滚,较为简单。


一、  本地回滚     

   

       git reset


       回退内容到上一个版本。就像现在的自己为成年人,想要回退到童年,直接用gitreset命令,直接回退到小时候。

       $ git reset --hard   22f8aae 。22f8aae 为某次提交的提交号。

       可以用git命令进行回退,也可以在intellij中可视化界面回退,如下。


       比如我们要回退到第二次提交,可以在提交log界面中,选中第二次提交,右键选择reset current branch to here,如下图所示。


       reset有几种模式,包括Hard 、Mixed、Soft、Keep,区别如下英文说明。





       git reset --hard HEAD~3 (回退3次提交)


       --hard:本地的源码和本地未提交的源码都会回退到某个版本,包括commit内容,和git自己对代码的索引都会回退到某个版本,就如上图所说,any local changes will be lost。


       --soft:保留源码,只能回退到commit信息到某个版本,不涉及到index的回退,如果还需要提交,直接commit即可。比如我选择soft方式来进行回退,我的本地代码和本地新添加的尚未commit的代码都没有改变。





       --mixed:会保留源码,只是将git commit和index信息回退到某个版本。



git revert

       如果错误的修改已经不是最新的commit,回退某次提交的上一步,用git revert。并且会生成一个新的提交来撤销某次提交,此次提交之前的commit都会被保留。

       就像是现在的自己是青年人,用git revert是无法退回到小时候,但可以修改小时候某次做过的事情,比如小时候和别人打架,可以直接清除这次打架记忆,但会生成一个最新的记录,会记录下曾经清楚过小时候这段记忆(我的理解是这样的,勿喷)。

       git revert c011eb3c20ba6fb38cc94fe5a8dda366a3990c61  回退该次提交(提交后的生成的唯一编号c011eb3c20ba6fb38cc94fe5a8dda366a3990c61 )


       以上的两种方式均为本地回滚,均不可以达到远程回滚的效果。要想把远程分支上的代码进行回滚,还需要如下操作。


       当我们的代码已经提交到远程,不但要回滚本地的代码,同时也要回滚远程的代码,如下操作。


二、 远程回滚

       方法一,先git reset回滚到本地,然后再强制push到远程。


       1,回滚到本地上述已经说明不再赘述。

       2,强推到远程分支(谨慎操作,胆小勿做,备份预备)


        git push -u origin master -f        origin:远程仓库名  master:分支名称  -f:force,意为强制、强行

       我们是要把本地的修改强制推送到远程分支上,在强推mster的可能会报错,意思是没有权限之类的错误,报错如下。

       remote: GitLab: You don't have permission
       To git@10.255.223.213:code-ddreader/media-hapi.git
        ! [remote rejected] master (pre-receive hook declined)


       是因为master分支一般会成为保护分支,所以我们首先要去除master为保护分支,才可以强推。

       为分支开启保护

              *管理员可以开启
              * 开启,无法强制推送
              * 开启,无法被删除
              * 只有测试全部通过才被接受合并

       该分支添加了保护权限,需要设置去掉保护权限(http://10.255.223.*/code-dd/media-project/protected_branches)。




       这样操作后就可以把本地强制推送要远程。


       方法二,先reset回滚到本地,然后再提交到一个新的分支,删除错误的分支(git brach -d master),再把新的分支重命名删除掉的分支。


       (ps这需要团队的其他人把本地的删除掉,然后重新下载一份,任何一个人未重新下载就可以出问题。)

       默认分支设置,也可能要删除的分支为 默认分支,造成删除默认分支失败。

       默认分支是无法删除的,遇到master远程仓库要回滚就会出问题,我们master是默认的主干,所以不允许删除,要删除的话还要设置一个新的分支为主分支。

       git config --global push.default "current"

       所以第二种方法也不是十分的好。


       方法三,对于少量的回滚,手动回滚

       对于少量的回滚,可以手动回滚,实在修改的文件太多,无法具细,再采用前两种方式。



       参考:http://stackoverflow.com/questions/32246503/how-to-fix-you-are-not-allowed-to-push-code-to-protected-branches-on-this-proje





本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

git 远程代码回滚master 的相关文章

随机推荐

  • 追求技术之路 - 那些陪伴我的书籍

    如今已经在广州一家嵌入式公司实习 xff0c 分享大学里度过的一些书籍 xff0c 有些还没读完 xff0c 个人比较喜欢经典书籍 xff0c 研读起来就有种奇妙的感觉 xff0c 比起人与人之间的复杂的关系 xff0c 书籍带给我的感觉很
  • 详解蓝牙标准中的GFSK调制

    简介 GFSK是一种简单但应用广泛的调制方式 xff0c 在蓝牙和802 11等无线通信标准中都有应用 802 11跳频FHSS时所用的调制方式是GFSK 2和GFSK 4 xff0c 采用BT 61 0 5的高斯滤波器 在GFSK 2和G
  • ajax入门 不要畏惧 很简单 进了门一切都好学多了

    以前总是听别人说ajax是多么的好 xff0c 然后自己就去借了本书看 xff0c 哇塞感觉好难哦 xff0c 什么介绍javascript html css xff0c 还有很多一些东西 看的那个难啊 xff0c 然后就是硬着头皮把它给看
  • IntelliJ IDEA With Git

    记录下Git如何与IntelliJ IDEA协作 文章目录 环境准备IntelliJ IDEA With Git 开发过程1 初次获取远端代码2 查看远端仓库分支3 将指定的远端分支同步到本地 xff08 建议同远端名一致 xff09 4
  • 环形缓冲区(ringbuffer)

    环形缓冲区 xff08 ringbuffer xff09 环形缓冲区是嵌入式系统中十分重要的一种数据结构 xff0c 比如在串口处理中 xff0c 串口中断接收数据直接往环形缓冲区丢数据 xff0c 而应用可以从环形缓冲区取数据进行处理 x
  • Gson解析异常:Use JsonReader.setLenient(true) to accept malformed JSON at line 1 column 1 path $

    首先检查你的retrofit配置是否正确 xff0c 解析异常 addConverterFactory GsonConverterFactory create 在这里修改成这个gson的 Retrofit retrofit 61 new R
  • leetcode|多线程专题

    1114 按序打印 我们提供了一个类 xff1a public class Foo public void one print 34 one 34 public void two print 34 two 34 public void th
  • OpenCV实战(1)——OpenCV与图像处理基础

    OpenCV实战 xff08 1 xff09 OpenCV与图像处理基础 0 前言1 OpenCV 基础1 1 安装 OpenCV1 2 OpenCV 主要模块1 3 使用 Qt 进行 OpenCV 开发 2 OpenCV 图像处理基础2
  • 1.机器视觉标准框架学习

    在工业机器视觉上 xff0c 常见的图像处理库有opencv halcon visionpro sherlcok等 其中visionpro和sherlcok是拖拽式编程 xff0c 方便用户开发视觉项目 但对于opencv 和halcon则
  • Gitlab权限说明

    Gitlab权限管理 Gitlab用户在组中有五种权限 xff1a Guest Reporter Developer Master Owner Guest xff1a 可以创建issue 发表评论 xff0c 不能读写版本库 Reporte
  • 二进制的浪漫

    0 基本性质 0 1 交换律 相同运算符下可任意交换 xff0c 不同的运算符不可交换 0 2 结合律 相同运算符是可结合的 0 3 分配律 a amp b
  • (九)分支限界法

    分支限界法 xff08 branch and bound method xff09 按广度优先策略搜索问题的解空间树 xff0c 在搜索过程中 xff0c 对待处理的节点根据限界函数估算目标函数的可能取值 xff0c 从中选取使目标函数取得
  • (七)贪心法

    贪心法比较简单 xff0c 从这个算法的名字看来差不多都了解了 xff0c 贪心 xff0c 贪心的人是只顾一时的利益 xff0c 不顾长远的利益 贪心法把一个问复杂问题分解为一系列较为简单的局部最优选择 xff0c 每一步选择都是对当前的
  • Struts旅程(一)Struts简介和原理

    struts 简介 Struts 是 Apache 软件基金会 xff08 ASF xff09 赞助的一个开源项目 它最初是 jakarta 项目中的一 个子项目 xff0c 并在 2004 年 3 月成为 ASF 的顶级项目 它通过采用
  • Struts旅程(六)Struts页面转发控制ActionForward和ActionMapping

    上篇讲述了 struts 控制器 Action 和 DispatchAction 以及 LookupDispatchAction xff0c 本篇主要说说 struts 中的页面转发控制 xff0c struts 提供了 ActionFor
  • Hibernate旅程(四)Hibernate对数据库删除、查找、更新操作

    上篇 xff0c 我们以向数据库添加操作来演示 hibernate 持久化对象的三种状态 本节继续 hibernate 对数据库的其他操作 xff0c 删除 查询 修改 Hibernate 对数据删除操作 删除 User 表中个一条数据 x
  • 二分查找算法(递归与非递归两种方式)

    首先说说二分查找法 二分查找法是对一组有序的数字中进行查找 xff0c 传递相应的数据 xff0c 进行比较查找到与原数据相同的数据 xff0c 查找到了返回对应的数组下标 xff0c 没有找到返回 1 xff1b 如下示例 xff0c 其
  • 调用微信高级群发接口--视频群发接口出问题(微信官方文档错误纠正)

    这几天在弄项目与微信对接 xff0c 我主要负责将素材 xff08 视频 xff0c 图片 xff0c 缩略图 xff0c 音频 xff09 材料上传到微信服务器上 xff0c 并推送到所关注本平台的用户中 xff0c 从获取accessT
  • (七)Intellij 中的git操作

    git原理以后会分章节介绍 xff0c 本次主要说一下intellij怎样操作git intellij有很好的git操作界面 xff0c 可以拉取代码 xff0c 拉取分支详情 xff0c 提交代码到本地仓库 xff0c 提交代码到远程仓库
  • git 远程代码回滚master

    人总是会有犯错的时候 xff0c 所以我们的代码有时候就需要回滚 当我们要回滚的代码还没有提交到远程的时候 xff0c 可以进行本地回滚 xff0c 较为简单 一 本地回滚 git reset 回退内容到上一个版本 就像现在的自己为成年人