- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在关注 a success Git branching model (又名 git-flow)。
我按照完成修补程序分支部分的指导进行了修补程序。
我在 master 之外创建了一个hotfix 分支:
> git checkout -b hotfix upstream/master
做了一些工作并手动将其 merge 到master:
> git checkout master
> git merge --no-ff hotfix
然后手动将其 merge 回dev:
> git checkout dev
> git merge --no-ff hotfix
我做了更多工作 - 针对 dev 进行了提交。一切似乎都很好。但是当我去 merge dev 到 master 时,它不能。
> git checkout master
> git merge --ff-only dev
fatal: Not possible to fast-forward, aborting.
hotfix 的 merge 提交似乎是不同之处。
我假设遵循这个过程会保持共同的历史记录。我做错了什么?
最佳答案
您没有提供有关历史拓扑结构的细节,因此从一般情况开始并创建 hotfix
给出
$ git checkout -b hotfix upstream/master$ git lola* 81a514a (dev) Stupendous feature* cb4d5e6 Great feature* d4a7906 Cool feature| * 39e449a (HEAD, upstream/master, hotfix) v0.2|/* 264ddbc (master) v0.1
备注:git lola
是一个非标准但非常有用的别名。
merge hotfix
到 master
给出
* 567f066 (HEAD, master) Merge branch 'hotfix'|\| * 1b1b6e3 (hotfix) Fix nasty bug| * 39e449a (upstream/master) v0.2|/| * 81a514a (dev) Stupendous feature| * cb4d5e6 Great feature| * d4a7906 Cool feature|/* 264ddbc v0.1
将 hotfix
单独 merge 到 dev
是偏离正轨的地方。
* 36aa1c8 (HEAD, dev) Merge branch 'hotfix' into dev|\* | 81a514a Stupendous feature* | cb4d5e6 Great feature* | d4a7906 Cool feature| | * 567f066 (master) Merge branch 'hotfix'| | |\| |/ /|/| /| |/| * 1b1b6e3 (hotfix) Fix nasty bug| * 39e449a (upstream/master) v0.2|/* 264ddbc v0.1
此时,master
不是dev
的直接祖先,而是它的兄弟。
向 dev
添加更多提交使 master
成为他的叔叔。
* d89aa74 (HEAD, dev) Jason does it again* a4dd5bf Jason saves the day* 36aa1c8 Merge branch 'hotfix' into dev|\* | 81a514a Stupendous feature* | cb4d5e6 Great feature* | d4a7906 Cool feature| | * 567f066 (master) Merge branch 'hotfix'| | |\| |/ /|/| /| |/| * 1b1b6e3 (hotfix) Fix nasty bug| * 39e449a (upstream/master) v0.2|/* 264ddbc v0.1
回想一下,dev
通过功能分支并通过 --no-ff
merge 到达 master
。也许 release-1.0
从您的修补程序开始并获得另一个错误修复。
* f0398ba (HEAD, release-1.0) Bugfix for v1.0* d89aa74 (dev) Jason does it again* a4dd5bf Jason saves the day* 36aa1c8 Merge branch 'hotfix' into dev|\* | 81a514a Stupendous feature* | cb4d5e6 Great feature* | d4a7906 Cool feature| | * 567f066 (master) Merge branch 'hotfix'| | |\| |/ /|/| /| |/| * 1b1b6e3 (hotfix) Fix nasty bug| * 39e449a (upstream/master) v0.2|/* 264ddbc v0.1
假设按下释放按钮,这将返回到 master
$ git merge --no-ff -m "v1.0" release-1.0$ git lola* 5a384c8 (HEAD, master) v1.0|\| * f0398ba (release-1.0) Bugfix for v1.0| * d89aa74 (dev) Jason does it again| * a4dd5bf Jason saves the day| * 36aa1c8 Merge branch 'hotfix' into dev| |\| * | 81a514a Stupendous feature| * | cb4d5e6 Great feature| * | d4a7906 Cool feature* | | 567f066 Merge branch 'hotfix'|\ \ \| |/ /|/| /| |/| * 1b1b6e3 (hotfix) Fix nasty bug| * 39e449a (upstream/master) v0.2|/* 264ddbc v0.1
当然,具体的解决方案取决于您的病史。
关于git - 将修补程序 merge 到 dev 和 master 中会导致分歧,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21337169/
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
i=5 expr $i + 6 1>/dev/null 将标准输出重定向到/dev/null。怎么样 expr $i + 6 >/dev/null expr $i + 6 1>/dev/null 和
在 R 中,可以握住设备,绘制图片,然后刷新设备来渲染图形。这对于具有数千个数据点、颜色渐变等的非常复杂的绘图非常有用,因为如果不保持,设备将在每次绘图操作后刷新。效果非常好。 但是,一旦绘图就位,任
我想通过串口dev文件执行IPC管道。这是要求首先我尝试使用 sudo socat /dev/ttyS0,raw,echo=0,crnl /dev/ttyS1,raw,echo=0,crnl 报错如下
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 10 年前。 Improve thi
我正在尝试使用 mpg123 播放随机歌曲命令行。但不知道我的默认音频设备是什么。或者如果我需要使用“-a”选项指定任何其他音频设备。/dev/audio 和/dev/dsp 都是音频设备。如何知道哪
我可以看到/dev/uinput 和/dev/input 都存在于我的 Ubuntu 中并且它们很相似。它们可用于检测/模拟按键/鼠标/触摸事件。所以我对它们之间的区别感到困惑?谢谢! 新增:是的,我
cat/dev/urandom 总是一种在显示器上创建滚动字符的有趣方式,但会产生太多不可打印的字符。 有没有一种简单的方法可以在命令行上对其进行编码,使其所有输出都是可读字符,例如 base64 或
是否可以在没有 bit.dev 帐户的情况下将 bit 设置为本地服务器以进行内部处理? 我知道您可能没有相同的功能 -- bit's FAQ page说“与 Bit CLI 不同,bit.dev 服
我试图在 Ubuntu 的启动过程中尽早采样一些随机性。我想知道是否有人建议如何做到这一点。我目前的想法是寻找/dev/random 和/dev/urandom 在引导序列中创建的位置,并在那里添加我
我正在尝试使用'dotnet dev-certs'工具导出https证书以包含在Docker镜像中。现在我正在使用: dotnet dev-certs https -v -ep $(HOME)\.as
我发现非常方便的 dev.copy2pdf 命令可以将我正在查看的窗口复制到 pdf 文件中,如下所示: plot(rnorm(1000)) dev.copy2pdf(file="myfile.pdf
谁能告诉我为什么从硬盘驱动器上清除数据时出于安全性考虑首选/dev/random? 最佳答案 简单的答案,/dev/random不是首选。两者同样安全。使用/dev/zero可以更轻松地进行验证。还可
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a software
我有一个从 initramfs 镜像启动的嵌入式 Linux(vanilla、3.3.8、i486、Vortex86dx)系统。 我有一个 IDE 闪存盘,在/dev/hda1 和/dev/hda2
在Linux中,/dev/ttyS0和/dev/ttys0有什么区别? 我知道第一个是串行端口,但第二个是什么,带有小的 s? 最佳答案 see this For a pseudo terminal
我有一些命名空间的测试被自动加载到包 A 中使用 "autoload-dev": { "psr-4": { "Vendor\\PackageA\\PhpUnit\\": "te
我意识到/dev/stdout 和/dev/stderr 文件在没有根目录的 Android 设备上不存在。我同意这一点——但我需要一些方法来在我的 shell 脚本中重定向输入/输出——包括将输出重
我想对使用 composer 安装的软件包的最低支持版本运行测试,但理想情况下我想要最新版本的开发软件包。 具体来说,我想运行它来安装最低版本的软件包以进行测试: composer update --
我必须将开发分支从 testing 重命名为 tom 。重命名后,我必须创建一个具有相同名称的开发分支,它是 testing 并且它应该指向 master 的特定提交。 我已将分支重命名为: git
我是一名优秀的程序员,十分优秀!