我所在的团队中有几个开发人员在Bitbucket上使用Git。我们都在一个开发分支上工作,在发布之前不催促master。

其中一个开发人员提交了错误的代码,不小心覆盖了我自己的代码,现在我正试图将正确的代码推回存储库。我已经阅读了关于这个错误的几天了,我不能再推送到存储库,因为我得到了以下错误:

 ! [rejected]        master -> dev (fetch first)
error: failed to push some refs to 'https://myusername@bitbucket.org/repo_user/repo_name.git'
hint: Updates were rejected because the remote contains work that you do
hint: not have locally. This is usually caused by another repository pushing
hint: to the same ref. You may want to first integrate the remote changes
hint: (e.g., 'git pull ...') before pushing again.
hint: See the 'Note about fast-forwards' in 'git push --help' for details.

我按照说明进行了拖动,但随后收到了合并冲突。在输入合并冲突的消息后,我的本地代码现在是其他开发人员意外上传的错误代码(正如从pull中预期的那样)。因此,我用提交前复制的备份替换了错误的代码,当我再次尝试推送时,我得到了相同的错误。

我该如何解决这个问题?

以下是我为了提交而运行的命令:

git pull remotename master:dev
git add --all
git commit -m "some message"
git pull remotename master:dev
git push remotename master:dev

我本以为,如果我保持这个顺序,就不会收到合并冲突。我想我错了。

我已经在谷歌和Stack Overflow上找了几个小时,并遵循了不同的指示,但我仍然无法将Git推送到开发分支。


当前回答

这通常发生在回购包含一些不在本地的项时。因此,为了推动我们的更改,在这种情况下,我们需要集成远程更改,然后进行推送。

所以从远程创建一个拉

git pull origin master

然后把更改推到那个遥控器上

git push origin master

其他回答

这对我来说是最好的选择,而且很简单

快拉,变基

then

git push

祝你好运

我也有同样的问题。碰巧我已经在存储库上创建了. readme文件,而没有先拉它。

您可能希望删除. readme文件或在推送之前将其拉出。

好吧,实际上github比我们想象的要简单得多,它绝对会发生,每当我们试图推,即使我们显式地插入一些文件在我们的git存储库,所以,为了解决这个问题,简单地尝试..

: git拉

然后. .

:git push

注意:如果你不小心卡在vim编辑器拉你的存储库比不要担心,只是关闭vim编辑器,并尝试推:)

Git pull -rebase origin master Git push origin master


Git push -f origin master

警告git push -f origin master

强制推动现有的存储库,也删除以前的存储库,所以如果你不需要以前的版本,这可能是有帮助的

1.Git拉源

2.根据您的需求接受更改,比如保留传入的更改或保留现有的更改。

3.Git add else给出Git add。 4.Git commit -m "保留你的提交信息"

5.Git推源

这对我很有效。如果对你不起作用请告诉我。