- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
首先,我是git分支的新手。我不知道每个功能分支都应该从master
分支出来,而仅使用与下一个功能分支具有这种关系的前提功能分支。
我有三个分支。 master
,feature-1
和feature-2
都推送了一个Bitbucket存储库(启用了问题跟踪)。问题是提交M4
和M5
是关键的提交,所有分支都应在提交合并之前将其重新定基(git rebase
的任务)
M1 -- M2 -- M3 -- M4 -- M5 [master]
\ /
A1 --- A2 [feature-1]
\
B1 -- B2 -- B3 [feature-2]
feature-2
的开发已完成,现在需要合并到master。这是我为
feature-2
为
M4
重新设置基准并将
M5
提交给
feature-2
所做的任务的优先级。
git push
-
feature-2
的发展
git checkout feature-2
git rebase master
git pull
git status
之后注意到了。我必须再次推送所有提交(
feature-2
,
M4
,
M5
和冲突提交)。好吧,我要做的就是执行
git push
并启动拉取请求,我完成了,对吗?但这会向问题跟踪器添加另一个git commit注释。
feature-2
重新设置为
master
,而无需再次推送
feature-2
,
M4
和
M5
的提交,并且
git log
应该包含冲突提交。
最佳答案
由于您已经推送了两个功能分支,因此根本不应该调整基准。强烈建议不要对已发布的分支机构进行重新定价,因为这会破坏其他开发人员的存储库。这样做的原因是,rebase只是对提交的完全重写。将重新创建您要重新部署的提交,更改内容,并且最重要的是使用不同的哈希值。这导致新提交与旧提交不兼容,因此,拥有旧提交的人最终会与替换新提交的冲突。
正确的解决方案是简单地合并更改。尽管这看起来可能不会看起来那么漂亮,但这是一种无损操作,其中不更改任何现有提交。所发生的一切就是添加了提交,这将在推入或拉出时没有问题。
话虽如此,您可以重新设置基础并仍发布已更改的分支。但是要这样做,您将需要强行推分支,而其他开发人员若要拉这些更改,就需要将其分支重置为新版本。
要将我在下面的一些评论纳入答案:请务必了解,在Git中,分支只是指向提交的指针。整个历史(无分支)是一个很大的无环图,其中提交仅指向其父提交。因此,以问题为例,这就是历史,没有任何分支指针:
A -- B -- C -- D -- E
\ /
F --- G
\
H -- I -- J
F
的父级是
A
,而
C
是与父级
B
和
G
的合并提交。
master
↓
A -- B -- C -- D -- E
\ /
F --- G ← feature-1
\
H -- I -- J
↑
feature-2
feature-2
分支。我们将该提交添加到树中...
\
H -- I -- J -- K
↑
feature-2
\
H -- I -- J -- K
↑
feature-2
\
H -- I -- J ----------- K
↑ ↑
origin/feature-2 feature-2
K
。但是服务器只有
J
,因此我们需要为服务器提供一切以构造
K
可以访问的树(因此,其间的所有其他提交以及这些提交的所有实际内容)。但是当然,我们不需要物理地推动
J
或
H
甚至
A
(尽管从技术上讲,这些都在
feature-2
分支上,因为您可以到达它们); Git足够聪明,可以找出实际上缺少哪些对象(您可以在开始推送时看到Git在计算该对象)。
feature-1
指针,因此它也将指向
K
。如果成功,我们还将更新我们的远程分支(
origin/feature-2
)也指向它(只是为了同步)。
master
合并到
feature-2
(在
git merge master
上使用
feature-2
):
master
↓
A -- B -- C -- D -- E -----
\ / \
F --- G ← feature-1 \
\ \
H -- I -- J -- K -- L
↑
feature-2
feature-2
,我们再次需要为远程存储库提供它没有的所有对象。由于我们现在正在进行合并提交,因此我们需要检查所有父级:因此,如果服务器没有
K
,则需要推送
K
;但是,如果它没有
E
,我们将不得不按下
E
。当然,我们需要再次跟随这些父母,以确保所有对象都存在于遥控器上。完成后,我们只需再次告诉遥控器更新分支指针即可。
git merge master
将
master
分支合并到
feature-2
中。如果我们改为使用
git rebase master
,则完整的树现在看起来像这样:
master feature-2
↓ ↓
A -- B -- C -- D -- E -- H' -- I' -- J' -- K'
\ /
F --- G ← feature-1
\
H -- I -- J -- K
↑
origin/feature-2
H'
,
I'
,
J'
和
K'
。这些是重写的提交,因此它们从
E
(在重新设置基准时指向
master
的地方)而不是
G
开始。由于我们已重新设置基础,因此没有合并提交
L
。并且如上所述,原始提交仍然存在。只是没有指针可以指向它们而已。因此它们“丢失了”,最终将被垃圾回收。
K
,但是我们现在希望它指向
K'
。因此,就像以前一样,我们开始为远程存储库提供它需要的所有对象。但是,当我们告诉它设置更新分支指针时,它将拒绝这样做。这样做的原因是,通过将指针设置为
K'
,它将必须“返回历史记录”,而忽略将
H
提交给
K
的情况。它不知道我们已经对它们进行了重新设置,并且在重写的和原始的之间也没有链接。因此,为了防止意外的数据丢失,遥控器将拒绝更新分支指针。
origin/feature-2
master feature-2
↓ ↓
A -- B -- C -- D -- E -- H' -- I' -- J' -- K'
\ /
F --- G ← feature-1
I
。因此,运行pull的功能与反向执行的功能相同:遥控器为我提供了完成历史记录所需的所有对象,然后它告诉我在何处设置分支指针。那时,我的本地Git拒绝这样做,原因与远程存储库之前这样做的原因相同。
关于git - GIT rebase 要求重新提交更改,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27856364/
我有一个类和构造函数,如下所示: def init(log, edge): if edge: return Helper(log, edge) return Booka
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 4年前关闭。 Improve this questi
有人知道在 mongo 上安装标准 ubuntu 需要多少磁盘空间和内存吗?试图找出我的 VPS 需求... 最佳答案 没有最低要求,但我不建议在与您的网络服务器相同的机器上运行 Mongo。 Mon
我的 Django 项目有一个虚拟环境,但是当我 pip 击 pip freeze 时,我得到了一个必须是全局站 pip 包列表的东西,包括太多包,比如ubuntu包和这么多不相关的东西。无论 vir
我曾尝试在 Heroku 上部署我的应用程序,但 smth 出错了。 错误:找不到满足要求的版本 get==2019.4.13(来自 -r/tmp/build_53ad6d03_/requiremen
我无法将 semantic-ui-calendar npm 模块加载到我的应用程序中。 我已经使用脚本标签成功地将它加载到我的 HTML 中, 但每次我尝试将它加载到我的应用程序中时,我都会出错。 在
如何修复 php.ini 中“require”函数内的地址?它进行故障排除并显示错误: 警告:require (..) 无法打开流:没有这样的文件或目录。 文件“db_connection.php”工
我有一个在 Node.js 应用程序中使用的外部库 ( Objection.js )。我创建了一个基本模型类,它为我的实体模型扩展了 Objection 的 Model 类: const { Mode
有谁知道在哪里可以找到RHEL5的GLIBC2.7,如果没有这个,Android模拟器将无法启动。它会给出一条消息,要求GLIBC 2.7或更高版本。 我尝试在网上搜索,但没有找到 最佳答案 我也遇到
Android 设备是否有任何要求/指南?例如按钮数量或所需的最少按钮数量。 还有没有菜单和后退按钮的安卓设备吗? (我知道就可用性而言,没有菜单/后退按钮会杀死大多数应用程序,我只是想了解更多有关该
我想要求/包含一个文件并将其内容检索到一个变量中。 test.php index.php ".$test; ?> 类似于 file_get_contents() 但它仍应执行 PHP 代码。这可能吗
我想要求/包含一个文件并将其内容检索到一个变量中。 test.php index.php ".$test; ?> 类似于 file_get_contents() 但它仍应执行 PHP 代码。这可能吗
我正在尝试在我的 Linux Mint 发行版上安装一个 python 模块“pyAudioProcessing”(https://github.com/jsingh811/pyAudioProces
我已经创建了我的第一个 composer 包,它具有 MySQL 和 MongoDB 的功能,但是,它不需要两者。我意识到有人可能只想将这个包与两个数据库之一一起使用,目前我有: "require":
我想调试以下函数,但假设在调试器中查看 moreajaj 的参数等于什么(假设不像在这个人为的示例中那么明显)是有用的。我可以在调试器框架中打印它,但是在每个参数的每个框架中都这样做很烦人。在宣布每一
我有一些生成的 GNUmakefiles,我需要从中提取变量的值。 有没有一种简单的方法可以在不修改 makefile 的情况下查看变量的值? 仅供引用,变量包含 emacs c-macro-expa
我正在使用 aspell 在 Linux 上拼写检查 LaTeX 文档。我的文档经常包含各种编程语言的代码示例,我希望 aspell 在拼写检查时简单地跳过这些行。 我可以在文档中写些什么来关闭一段文
我有一个包含多个列的数据集... 一列是具有重复值的主石斑鱼列,另一列是具有 bool 值 (1,0) 的 NUMBER,如下所示: grp bool --- ---- A 1 A 1 A
出于测试目的,我正在尝试删除一些 amd 模块并从服务器重新加载更新版本 - 目的是不刷新浏览器。 我目前正在执行以下操作,但浏览器仍然没有从网络重新加载项目。 var scripts = docum
当我键入irb> require 'rubygems'时,它返回false。我的Rails应用程序中有很多 gem ,这些 gem 显然可以正常工作-耙子,activerecord等。这里可能出什么问
我是一名优秀的程序员,十分优秀!