- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我开始了一个工作流程,我的目标是在 development
分支中完成所有新功能,而 master
分支将仅用于生产就绪代码。
完成以下操作后:
git checkout master
git merge staging
我收到了一堆这样的冲突:
CONFLICT (rename/add): Rename app/assets/stylesheets/mobile.css->app/assets/stylesheets/application.css in HEAD. app/...
CONFLICT (modify/delete): app/views/organizers/mobile.html.erb deleted in HEAD and modified in staging. Version stagi...
CONFLICT (modify/delete): app/views/events/mobile.html.erb deleted in HEAD and modified in staging. Version staging of app/v...
当我现在用谷歌搜索这个时,我所读到的只是检查每个文件、解决冲突并提交更改。但我看不出做这一切有什么意义,因为我知道代码,而且它只是同一代码集的进步。
如何以简单的方式将 staging
中所做的更改 merge 到 master
中,而无需审查和解决每个更改?
最佳答案
这是一个复杂的问题,因为它基本上意味着 git
无法直观地弄清楚如何组合两个分支。似乎一些文件在 master
上被删除,然后在 staging
中修改(因此被使用),而另一个在 master
中重命名但添加到 staging
。以下将主要是在黑暗中拍摄,您可能仍然需要手动解决一些(但希望更少)冲突。
git
可以选择多种不同的 merge 算法,因此我们将使用最简单、易于定制且通常默认使用的一种:递归策略。我们将通过选项 -s recursive
强制使用它。
帮助 git
的第一步是让它花更多时间改进补丁,因此我们将使用选项 -Xdiff-algorithm=histogram
。这将花费最长的时间,但它会强制 git-merge
产生更好的差异输出(这有望减少冲突)。
下一步是告诉 git-merge
花更多时间进行正确的 merge 。我们将使用 -Xpatience
选项来执行此操作。
由于 master
将依赖于重命名/修改的文件,而 staging
将依赖于旧文件,我们可以尝试欺骗 git
认为该文件并没有真正用选项 -Xrename-threshold=100%
重命名(因此文件必须相同才能被视为重命名)。请注意,您可能遗留了一些冗余文件,并且对需要注意其他文件名的文件进行的任何更改都不会记录旧名称(仅记录新名称),因此您可能想返回并修复这些文件一旦你'已经完成 merge 。您还可以将 100%
调整为更小的值(默认值为 50%
,目前这会导致问题)。
现在要包含 staging
所需的文件,我们可以使用以下选项强制添加它们:-Xtheirs
。 警告:此选项将默认忽略所有 merge 冲突并仅使用 staging
的内容。确保运行完整的测试套件以检查是否存在任何不一致。如果在 merge 后测试套件中确实存在问题,请使用 git reset --hard HEAD^
撤消它并重做没有这个选项的 merge 。您可能会遇到少量必须手动解决的 merge 冲突,但您会知道错误的来源来自其中一个(有限多个)冲突,这是在前面猜测的巨大飞跃一个调试器。
最后,我们把它们放在一起得到
git checkout master
git merge staging -s recursive -Xdiff-algorithm=histogram -Xpatience -Xrename-threshold=100% -Xtheirs
最后,我建议您尝试一下这些选项。花费在 merge 上的额外时间可能会使最后两个选项无用(甚至变得更糟)。
将来,我建议您定期将 master
中的任何更改 pull 到您的主题分支。这不仅会更早地呈现冲突(因此一次冲突较少),而且还会使您及时了解最新情况,甚至可以在冲突发生之前解决它们。这很好的另一个原因是 git
有一个名为 git-rerere
的功能,它记录您手动解决的冲突,然后学习如何稍后自动为您解决这些相同的冲突。因此,一旦您解决了一次,您就不必再次解决相同/相似的冲突。
关于git - 从 development merge 到 master 时处理冲突,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19516060/
我在 2 个不同的节点中设置了 master-master mysql 复制。假设如果我要再添加一个节点,即 3rd master ,我是否需要在新服务器中拥有与节点 1 和节点 2 中完全相同的数据
我认为我在理解 git 的基本概念方面是正确的。 我已经设置并克隆了一个远程存储库。我还创建了一个服务器端空存储库,并将我的本地存储库链接到它。 我的问题是我不明白: origin/master 与
从概念上讲,Master-Master 复制是如何工作的? 我认为碰撞将是一种需要以某种方式解决的常见事件。 最佳答案 主-主复制(更一般地——多主复制)在概念上的工作原理是假设冲突并不常见,并且只保
众所周知,mysql 是异步复制的。我听说我需要一些额外的插件来做 同步复制。 那么让我们考虑一下异步复制的情况:master 将事件写入其二进制日志,但不知道 master2 是否或何时检索并处理了
我正在寻求有关 MySql Master-Master 配置问题的帮助。 我正在处理由另一名员工设置的服务器配置,该员工现在无法就此事提供任何帮助。这是我第一次体验这样的设置,在做了相当多的研究之后,
尝试使用 HADOOP 运行 HBASE 时出现以下错误HBASE 0.98.xHADOOP 2.4.0 ERROR [main] master.HMasterCommandLine: Mas
停止独立 Spark Master 失败并显示以下消息: $ ./sbin/stop-master.sh no org.apache.spark.deploy.master.Master to sto
我不确定这是否是一个正常的分支场景,但是...... 假设我从 master 创建一个分支,比如分支 C,然后 merge 回其他先前存在的分支,比如分支 A 和 B,回到 master,然后我需要分
我无法推送到我的 git 存储库。 git clone和 git pull工作正常,但 git push不起作用。 我检查了其他答案,如 here尝试了几种方法,例如 git push origin
所以如果我在 master 中做: git checkout -b my-branch 并在那里做几次提交+推送。然后我做: git checkout master git pull 我现在能以某种方
我设置了 2 个 MYSQL 服务器: my.cnf server1: auto_increment_increment = 2 auto_increment_offset = 1 my.cnf se
我想知道一个服务器是否可以同时是slave和master。我们的问题是我们有很多移动单元需要同步到主服务器,但它们只需要主服务器上 100 个表中的 6 个。除了延迟同步和增加数据成本之外,所有额外的
我有主-主 Mysql 复制。每个主控复制其他主控。谁能解释一下为什么该主机上的 log-bin 文件不同? (尺寸差异很小)。谢谢! 最佳答案 嗯。我们决定使用 mysql 5.6 及其功能 - G
我正在努力理解这里的逻辑,如果术语不正确,我深表歉意。 我正在尝试构建一个功能类似于邮件的应用程序,IE: 所有邮箱 > 特定邮箱 > 消息 其中“所有邮箱”和“特定邮箱”占据 Controller
我一直在使用 master 分支进行开发,并希望将其清除为只有发布提交,以及它的用途。如何将所有内容从 master 复制到开发分支,然后重新启动 master? 最佳答案 Create develo
两周前,我创建了一个新分支,我们称它为exp。在此期间,exp 和 master 中都有几次提交。在此期间,exp 尚未更新 master 的更改 现在我想把所有从 exp 到 master 的更改都
我克隆:https://github.com/vy2014/git_lesson.git 然后我做了一些改动,尝试通过命令git push推送到远程服务器,但是错误: Counting objects
有没有好的方法来解释如何在 Git 中解决“![rejected] master -> master (fetch first)'”? 当我使用此命令时 $ git push origin maste
我该怎么办: 1)恢复推送到主(远程)的更改 2)将这些更改移动到单独的分支 3) 稍后将这些更改移回 master 最佳答案 首先做 2),但前提是你真的需要分支。 git branch chang
符号上有什么区别? 在我的一个工作站上,我克隆的 git 存储库显示(master),而另一个工作站则显示(master -> origin) 我还创建了一个新的本地存储库,提交了一个文本文件,提示仍
我是一名优秀的程序员,十分优秀!