- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在处理我的存储库的另一个分支,需要从 master 分支引入更改。我习惯于执行 git rebase master
,一切正常。然而,在最近的几个项目中,我看到日志中重复提交,并且 rebase 往往会提示(大声):
$ git log --graph --abbrev-commit --decorate ...
* 4988d49 - (2 hours ago) Merge branch 'branchname' of ... 3
|\
| * e979be1 - (2 days ago) change verbiage 10
| * 93a1c80 - (2 days ago) Merge branch 'branchname' of ... 2
| |\
| | * 4e4e790 - (2 weeks ago) Merge branch 'branchname' of ... 1
| | |\
| | | * 87cc232 - (8 weeks ago) change verbiage 3
| | | * 3d5cf09 - (8 weeks ago) change verbiage 2
| | | * aea4cbd - (9 weeks ago) change verbiage 1
| | * | a7043ef - (2 weeks ago) change verbiage 6
| | * | fa3413b - (2 weeks ago) change verbiage 5
| | * | be038a7 - (2 weeks ago) change verbiage 4
| | * | 37cb1e6 - (8 weeks ago) change verbiage 3
| | * | 1ab71c6 - (8 weeks ago) change verbiage 2
| | * | c4560f4 - (9 weeks ago) change verbiage 1
| * | | d3211fd - (2 weeks ago) change verbiage 6
| * | | 72a2a4a - (2 weeks ago) change verbiage 5
| * | | ae1c123 - (2 weeks ago) change verbiage 4
| * | | 8328c08 - (8 weeks ago) change verbiage 3
| * | | e52588f - (8 weeks ago) change verbiage 2
| * | | 114cbec - (9 weeks ago) change verbiage 1
* | | | 38bd6ce - (2 hours ago) change verbiage 9
* | | | 5aaf360 - (2 hours ago) change verbiage 8
* | | | 2745790 - (2 days ago) change verbiage 7
* | | | 7bb613f - (2 weeks ago) change verbiage 6
* | | | 726a312 - (2 weeks ago) change verbiage 5
* | | | 771dd7f - (2 weeks ago) change verbiage 4
* | | | b451926 - (8 weeks ago) change verbiage 3
* | | | 484d5dc - (8 weeks ago) change verbiage 2
* | | | 630df34 - (9 weeks ago) change verbiage 1
(为简单起见,我更改了提交消息。这里实际上只显示了一个分支,尽管有四个“管道”。)我已经对这个项目做了一些 rebase,我认为它们可以被追踪而是简单地基于(比如)更改措辞 1 的重复次数。
我认为我正在通过 rebase merge 来对项目工作流程进行“最佳实践”。我认为至少有一个以前的 rebase 是用 -no-ff
完成的,但我看不出行为有什么不同。
重放提交时,它们会发生冲突(显然,将一个提交放在其自身之上是有问题的),因此我不得不进行交互式 rebase ,删除所有重复的提交。
无法访问存储库本身,这是我工作流程的问题吗?是否说明分支存在其他问题?
最佳答案
看起来您使用 rebase 修改了旧的提交,另一个分支也已经指向了。所以发生的事情是:
你有一个看起来像这样的狗:
* abc123 (master) Most recent commit
|
| * f00ba12 (foo, HEAD) Some feature you're working on
| |
|/
* 192837 Fix the things
|
* 348cc87 Remove Peter's garbage code
|
* 000a0a WOOOORRRDDDDDSSSS
所以你目前正在 foo
上做一些事情,但你意识到你仍然有一些 Peter 的垃圾代码遗留下来并且想要删除它。作为优秀的程序员,您希望这些更改与其他更改一起提交 348cc87
。所以你做了一个 rebase 来回到那个点并修改中的变化。
这看起来不错吧?事情是,你改变了 348cc87
所以它不再是 348cc87
了。现在它是 111222
,因为请记住,提交哈希是根据项目的树计算的,等等。其中之一是父提交哈希 (000a0a
)。因此,由于 348cc87
现在是 111222
,“192837”被重新计算为 999999
并且 f00ba12
更改为 ba12f00
。所以现在你的 HEAD 日志看起来像
* ba12f00 (foo, HEAD) Some feature you're working on
|
|
* 999999 Fix the things
|
* 111222 Remove Peter's garbage code
|
* 000a0a WOOOORRRDDDDDSSSS
这成为一个问题,因为 abc123
仍然指向 192837
,这是有效的,因为提交对象 192837
仍然存在于 git 中。这是因为从 git 的角度来看,192837
和 abc123
是截然不同的提交,只是恰好具有相同的日志消息。
所以现在你的 git dag 看起来像:
* abc123 (master) Most recent commit
|
| * f00ba12 (foo, HEAD) Some feature you're working on
| |
| * 999999 Fix the things
* | 192837 Fix the things
| |
| * 111222 Remove Peter's garbage code
* | 348cc87 Remove Peter's garbage code
|/
* 000a0a WOOOORRRDDDDDSSSS
现在,当您完成 foo
分支的工作并准备好 merge 时,您会得到
* 5f93da (master) Merge 'foo' into 'master'
|\
* | abc123 Most recent commit
| |
| * f00ba12 (foo, HEAD) Some feature you're working on
| |
| * 999999 Fix the things
* | 192837 Fix the things
| |
| * 111222 Remove Peter's garbage code
* | 348cc87 Remove Peter's garbage code
|/
* 000a0a WOOOORRRDDDDDSSSS
经常这样做,你最终会陷入目前的境地。
但是 Kyle,我该如何解决这个问题?别急,我马上就到了。
有几种方法可以解决这个问题,我所知道的所有方法在特定情况下都有些复杂。
您可以将很多东西压在一起以减少提交次数,但您会丢失一些历史记录,我不喜欢这样。
您可以做一些更多的 rebase 魔术来更改您的“abc123”提交,以将更新的 999999
提交作为其父提交。您可以为此使用 --onto 参数。根据这种情况下的提交数量,这可能具有挑战性。
您可以保持原样。只要大师的提示处于正确的状态,这并不可怕,但会让您回顾历史变得非常困难。
是的。这看起来像是您的工作流程有问题。出于这个原因,编辑历史往往不是一个好主意,您通常应该避免这样做。
对我来说,master
跟踪公开的内容。我和我的队友都是根据这些代码进行更改的。我从不修改 master 中的提交。首先,因为我们的内部 git 存储库不允许我推送这样的更改(即使使用 --force),其次,因为这会弄乱我队友的代码(并将他们放到你的位置)。
我为特定功能创建了 master
的功能分支,所以我将有分支 foo
、bar
、fizz
和 buzz
都是 master 的独立分支,而不是彼此分离。这让我可以独立地处理每一个。我通常不会从功能分支分支出来,但是当我这样做时,我通常不会对提交历史进行任何编辑。那是因为我通常会在 merge 之前清理分支,所以我不需要这样做。
关于git rebase,提交重复,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35789982/
假设我有一个带有隐藏提交按钮的表单,我在其中输入值,然后我点击一个按钮,就会出现带有确认消息和确认按钮的对话框。当我单击“确认”按钮时,我还单击了表单中隐藏的提交按钮。这可能吗?我如何在 JQuery
我们正在学习 Git 并使用 GitHub 作为我们的托管站点。 我们都 fork upstream repo 并 PR 我们的提交到 upstream 以获取我们的更改。 我们正在努力学习如何压缩我
我只需要一些关于这段代码的帮助。 var prv3; var markIt3 = function(e) { if (prv3 === this && this.checked) { th
如果 1 个表单使用“GET”方法而另一个使用“POST”方法,我如何提交位于同一页面上的 2 个表单。每个表单都有相同的操作并转到相同的下一页。需要帮忙。感谢大家的帮助。 我怎样才能得到下面这两个使
您好,我的表单中有以下脚本 function pdf() { var frm = document.getElementById("form1"); frm.action = "http://www.
我有一个 iOS 胖静态库(iphoneos 和 iphonesimulator),如果我在应用程序提交期间使用它,它会因为二进制文件包含 iphonesimulator 代码而失败吗? 最佳答案 我
我似乎有一个卡住的 git repo。它卡在所有基本的添加、提交命令上,git push 返回所有内容为最新的。 从其他帖子我已经完成了 git gc 和 git fsck/ 我认为基本的调试步骤是
我正在尝试发送由 jquery 创建的表单。该表单附加到一个 div 中,下面的变量“data”是使用 php 创建的,我将只发布最重要的 js 代码。 我尝试了很多带有和不带有“on()”的操作,但
我面临一个简单的问题,但不知道如何解决。我正在使用 twitter bootstrap 的标签。选项卡有效,但每个选项卡中的表单不提交。表单在没有选项卡的情况下提交。 以下是我用于标签的链接
我的计算机上有 140 个 git 存储库,每周我可以处理其中 10-15 个。有没有办法知道是否忘记提交/推送我的一个项目? 这些存储库都位于同一位置:“C:/Projects”。 输出类似于 C:
我对 javascript 完全陌生,目前正在开发我的第一个函数。我有这 2 个文本输入区域,可以在其中输入他的姓名和级别。 Nom: Niveau (1 á 6): 提交后,
我安装了最新的 Docker CS,得到了 LAMP image来自 Docker 集线器。我正在尝试在其中创建一个数据库并使用保存在其中的数据库制作一个新图像。 启动容器:docker run --
我有这个 jQuery 简单代码: 由于某种原因,submit() 无法正常工作(我的表单在单击 old_thumb 按钮后未提交。有人可以帮助我吗? 这里是 html 的一部分(它很长
如何获得 input type="submit"onclick 事件来触发 commitfunds.valdiate?我不能使用类或 ID。它必须是一个 onclick 事件。 这是代码: row A
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and th
来自 this earlier thread我以为我知道可以使用 javascript submit() 命令通过 POST 方法发送表单数据。但我无法让它工作。这个演示在目的方面没有明显的意义,但请
在 mysql 重新启动时提交 XA 待处理事务时,出现以下错误。请帮助我解决这个错误。 mysql> XA RECOVER CONVERT XID; +----------+------------
我有一个带有 的表单. 如果启用了 Javascript,我将删除此 submit -输入字段$('#no-js-submit').remove();并添加“fire-ajax”按钮 $('Fire
我希望在页面加载后提交此表单,并且我使用了以下代码来完成此操作。问题是页面不断重新加载并停留在该循环中。 HTML Select Genre
我们有一个表单,其中有几个单独的提交按钮,它们执行不同的操作。问题是我有几个具有以下 HTML 的按钮: 现在您无法使用标准的 find_control 函数按值定位元素。所以我写了一个谓词函数来
我是一名优秀的程序员,十分优秀!