首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >我将一个分支与一个过期的本地主分支合并,并推送。如何撤消?

我将一个分支与一个过期的本地主分支合并,并推送。如何撤消?
EN

Stack Overflow用户
提问于 2020-09-19 01:48:08
回答 1查看 50关注 0票数 2

我一直在为一个项目的分支工作,这个项目是100+在master之前提交的。在过去的几天里,一位同事将一些更改推给了大师,而我从未将新的更改应用到我的本地环境中。

在我急于部署我的工作时,我忘记了首先从源/主服务器拉入,我将我的大分支与我的本地主服务器合并并推送到远程存储库。

现在我同事的所有更改都被删除了,而我似乎找不到恢复这些更改的方法。

我有什么选择?

EN

回答 1

Stack Overflow用户

发布于 2020-09-19 02:37:50

不要惊慌。它们都可以恢复。

最重要的是,在没有确切了解它们在做什么的情况下,不要再对进行任何推送。也许可以等到周一你的同事们回来。

如果没有--force,您就不应该能够进行推送。发生了一些其他的事情。让我们用图表来解决这个问题。

我一直在为一个项目的分支工作,这个项目是100+在master之前提交的。在过去的几天里,一位同事将一些更改推给了大师,而我从未将新的更改应用到我的本地环境中。

让我们称之为提前3次提交。您的本地repo如下所示。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
          [origin/master]
A - B - C [master]
         \
          D - E - F [feature]

遥控器看起来像这样。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
A - B - C - G - H - I [master]

在我匆忙部署我的工作时,我忘记了首先从源/主节点拉取,并且我将我的大分支与我的本地主节点合并...

在合并之后,您的repo将如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
          [origin/master]
A - B - C --------- M [master]
         \         /
          D - E - F [feature]

...and已推送到远程存储库。

你不能没有--force,因为你的本地主机和原始主机已经有了分歧。如果我们在git fetch之后查看您的回购,它将变得更加清晰。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
          G - H - I [origin/master]
         /
A - B - C --------- M [master]
         \         /
          D - E - F [feature]

您的master不能通过简单地添加提交到simply /master来应用。git push将无法工作。

这里缺少一些东西。可能是因为...

你使用的git push --force.

  • Your同事从未推送到master.

  • ???

无论哪种方式,下面是你修复它的方法。

  1. 让您的同事git push --force他们的主分支。

这将恢复他们的master版本。

  1. 如果您删除了分支,请在合并之前重新创建分支。

您将需要它来重做合并。在上面的示例中,它将是git branch feature F

  1. git fetch

这将更新你对起源的想法。origin/master现在应该在同事的工作中。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ git fetch

          G - H - I [origin/master]
         /
A - B - C --------- M [master]
         \         /
          D - E - F [feature]

  1. 签出母版和git reset --hard origin/master.

这将清除本地对master的更改,并将其恢复到源/master,从而有效地撤消合并。它只是将您的master标签移动到origin/master所在的位置。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ git checkout master
$ git reset --hard origin/master

                      [origin/master]
A - B - C - G - H - I [master]
         \
          D - E - F [feature]

  1. 重做合并。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ git merge feature

                    [origin/master]
A - B - C - G - H - I - M [master]
         \             /
          D - E ----- F [feature]

  1. git push.

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ git push

                          [origin/master]
A - B - C - G - H - I - M [master]
         \             /
          D - E ----- F [feature]

一旦解决了所有这些问题,考虑将master设置为受保护的分支,不能直接推送到该分支;对master的所有更改都必须经过一个集成步骤,如拉入或合并请求。GitLabGithub提供受保护的分支。或者可以用hooks来完成。

这避免了愚蠢,并确保master是一个稳定的代码库。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63964533

复制
相关文章
访问令牌JWT
By reference token(透明令牌),随机生成的字符串标识符,无法简单猜测授权服务器如何颁 发和存储资源服务器必须通过后端渠道,发送回OAuth2授权服务器的令牌检查端点,才能校验令牌 是否有效,并获取claims/scopes等额外信息
乐心湖
2020/08/02
1.7K0
GitLab 冷知识:在 Gitlab CI Pipeline 中进行 Git Push 操作 🦊
在日常工作中,经常会遇到这样一种场景:需要在 GItLab CI Job 中进行 Git Push 操作,将修改或构建好的代码推送到远端 Git 代码仓库当中。这是一个十分常见操作,本篇文章将会提供一个最简单且实用的方法来实现这个场景,希望对您有所帮助。
郭旭东
2022/12/05
5.5K0
GitLab 冷知识:在 Gitlab CI Pipeline 中进行 Git Push 操作 🦊
Gitlab CI 在 Kubernetes 中的 Docker 缓存
前面我们有文章介绍过如何在 Kubernetes 集群中使用 GitLab CI 来实现 CI/CD,在构建镜像的环节我们基本上都是使用的 Docker On Docker 的模式,这是因为 Kubernetes 集群使用的是 Docker 这种容器运行时,所以我们可以将宿主机的 docker.sock 文件挂载到容器中构建镜像,而最近我们在使用 Kubernetes 1.22.X 版本后将容器运行时更改为了 Containerd,这样节点上没有可用的 Docker 服务了,这个时候就需要更改构建镜像的模式了,当然要实现构建镜像的方式有很多,我们这里还是选择使用 Docker 来构建我们的 Docker 镜像,也就是使用 Docker IN Docker 的模式。
我是阳明
2021/11/17
1.5K0
在 Gitlab CI 中调用 Sonarqube 进行代码扫描
Gitlab 提供了基于 Code Climate 的代码质量评估功能,这一功能是通过 dind(Docker in Docker)方式运行的,在 Kubernetes 环境中、尤其是托管集群中,这种方式不太合适,还好还有一个替代方案:Sonarqube,通过在 .gitlab-ci.yml 中的设置,可以使用 Sonarqube 对代码进行扫描,接收到 Commit 之后,Sonarqube 会生成针对提交的代码质量提示,如图所示:
崔秀龙
2019/07/22
8.1K0
在 Gitlab CI 中调用 Sonarqube 进行代码扫描
Gitlab - 安装的社区版 Gitlab-ce,解决访问网页报502-Whoops, GitLab is taking too much time to respond的问题
在自己虚拟机(centos7)上装了 Gitlab-ce,就是社区版的 Gitlab,版本是 13.0+
小菠萝测试笔记
2021/04/25
5.2K0
Gitlab - 安装的社区版 Gitlab-ce,解决访问网页报502-Whoops, GitLab is taking too much time to respond的问题
持续集成gitlab-ci.yml配置文档基础
[TOC] 0x00 简述 Q:什么是.gitlab-ci.yaml?它有什么作用? 答:gitlab-ci全称是gitlab continuous integration的意思就是持续集成;gitl
全栈工程师修炼指南
2020/10/23
15K1
持续集成gitlab-ci.yml配置文档基础
面向个人开发者应该打造的CICD部署系统
作为一个个人开发者,在业余时间也会想着开发一些个人的好玩的项目,去开发一些效率工具,开发一些自己喜欢的程序,在这个前提下,很多人购买了自己的服务器,作为一个前端开发,在最开始的时候对服务器相对会比较陌生,如果接触不多,在部署自己的项目过程中也会有许许多多的不便,我们也可以为自己搭建一套自动化部署,能够让我们在开发个人项目的时候享受同样的便捷。
Snine
2022/09/28
1.4K0
面向个人开发者应该打造的CICD部署系统
持续集成gitlab-ci.yml配置文档基础
[TOC] 0x00 简述 Q:什么是.gitlab-ci.yaml?它有什么作用? 答:gitlab-ci全称是gitlab continuous integration的意思就是持续集成;gitl
全栈工程师修炼指南
2022/09/29
12.2K0
持续集成gitlab-ci.yml配置文档基础
gitlab配置https方式访问
前提:gitlab我安装的版本是13.*,已可以通过域名访问。 mkdir /etc/gitlab/ssl cp server.crt server.key /etc/gitlab/ssl vim /etc/gitlab/gitlab.rb 修改内容如下: nginx['ssl_certificate'] = "/etc/gitlab/ssl/ebyh.crt" nginx['ssl_certificate_key'] = "/etc/gitlab/ssl/ebyh.key" external_ur
休辞醉倒
2019/07/25
4.6K0
访问令牌过期后,如何自动续期?
JWT是JSON Web Token的缩写,是为了在网络应用环境间传递声明而执行的- -种基于JSON的开放标准((RFC 7519)。JWT本身没有定义任何技术实现,它只是定义了一种基于Token的会话管理的规则,涵盖Token需要包含的标准内容和Token的生成过程,特别适用于分布式站点的单点登录(SSO) 场景。
Tinywan
2023/03/08
2.7K0
访问令牌过期后,如何自动续期?
多分支流水线任务对 GitLab SCM 的支持
这个插件还没有二进制文件可用,因为这个插件还处于非常早期的 alpha 阶段,还没有为公众准备好。如果您想尽早介入,可以尝试自己从源代码构建它。
LinuxSuRen
2019/07/15
1.8K0
多分支流水线任务对 GitLab SCM 的支持
XXL-JOB访问令牌(AccessToken)设置
为提升系统安全性,调度中心和执行器进行安全性校验,双方AccessToken匹配才允许通讯;
Li_XiaoJin
2022/12/28
20.8K0
XXL-JOB访问令牌(AccessToken)设置
C/C++ 实现提升访问令牌权限
在我们编程实现一些系统操作的时候,往往要求我们执行操作的进程拥有足够的权限方可成功操作。比如,我们使用 ExitWindows 函数实现关机或重启操作的时候,就要求我们的进程要有 SE_SHUTDOWN_NAME 的权限,否则,会忽视不执行操作。这时,我们唯一能够做的,就是按照要求,提升我们进程的权限。
微软技术分享
2022/12/28
7900
gitlab访问限制问题------Forbidden
重启-gitlab:       gitlab-ctl restart          
Wyc
2018/09/11
2.5K0
Spring Security的项目中集成JWT Token令牌安全访问后台API
最近接了一个私活项目,后台使用的是Spring Boot脚手架搭建的,认证和鉴权框架用的Spring Security。同时为了确保客户端安全访问后台服务的API,需要用户登录成功之后返回一个包含登录用户信息的jwt token, 用于调用其他接口时将此jwt token携带在请求头中作为调用者的认证信息。最近一个多月一方面在忙着做这个项目,另一方面恰好遇上了精彩的世界杯,也没怎么发文了。很多时候真的深感写篇原创文章比单纯的敲代码麻烦多了,但是好久不更文还是要检讨一下自己的惰性,客服自身的惰性是每个想要突破自我、不甘平庸的普通人的一辈子都不能松懈的重任。
用户3587585
2023/03/09
4.3K0
Spring Security的项目中集成JWT Token令牌安全访问后台API
Ubuntu上如何使用GitLab CI搭建持续集成Pipeline
GitLab Community Edition是一个自托管的Git存储库提供程序,具有帮助项目管理和软件开发的附加功能。GitLab提供的最有价值的功能之一是内置的持续集成和交付工具GitLab CI。
爆栈工程师
2018/08/13
3.9K0
Ubuntu上如何使用GitLab CI搭建持续集成Pipeline
从外部访问Kubernetes中的Pod
本文主要讲解访问kubernetes中的Pod和Serivce的几种方式,包括如下几种:
我的小碗汤
2019/07/30
2.9K0
安装 GitLab CE
DevOps 理念落实得最为彻底的一类案例就是 CI/CD(持续集成/持续交付) 系统
franket
2021/08/12
3.6K0
使用GitLabCI实现monorepos项目CI/CD
基于现代Web的应用程序通常都包含多种服务。例如,后端API和前端客户端。在规模扩大成为问题的大型项目中,服务也可以拆分为多个微服务。如何在这样的项目中组织源代码?一种解决方案是monorepo,即项目中所有源代码在同一个存储库中管理。还有一种是每个微服务分别创建一个存储库管理。
DevOps云学堂
2020/06/19
9.5K0
GitLab 简明维护指南(v2020.05)
本文使用「署名 4.0 国际 (CC BY 4.0)」许可协议,欢迎转载、或重新修改使用,但需要注明来源。 署名 4.0 国际 (CC BY 4.0)
soulteary
2020/05/05
6550
GitLab 简明维护指南(v2020.05)

相似问题

如何从TinyMCE编辑器中获取字数统计?

13

如何在ck编辑器中输入文本时显示字数统计

123

在文本编辑器中显示XML (例如,tinymce,Jquery编辑器) PHP

10

在TinyMCE编辑器中显示视频

1109

如何在tinyMCE编辑器中显示RTF文本

113
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文