我所在的团队中有几个开发人员在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推送到开发分支。


当前回答

如果你已经用ReadMe文件初始化了一个新的GitHub repo,并且还收到了一个致命的错误,像这样:

致命的:拒绝合并不相关的历史

然后你可能想试试下面的命令:

git pull origin master --allow-unrelated-histories

现在你可以尝试将你的项目推到你的新存储库:

git push origin [branch]

注意:如果你已经在Github中初始化了存储库,并且在本地提交,那么你需要使用上面建议的命令,第一个命令“git pull origin…”否则,您可以简单地键入以下命令:

git pull origin [branch]

希望对大家有帮助。

其他回答

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

快拉,变基

then

git push

祝你好运

当我们试图推送到远程存储库,但已经在远程上创建了一个尚未提取的新文件时,就会发生这种情况,比如说Readme。在这种情况下,正如错误所示

Git拒绝更新

由于我们在本地环境中没有采取更新的远程。 所以先从远程取拉

git pull

它将更新您的本地存储库并添加一个新的Readme文件。 然后将更新后的更改推送到远程

git push origin master

我已经完成了以下步骤。终于可以正常工作了。

步骤

1) git init

2) git状态(用于检查状态)

3) git添加。(添加所有更改文件(.))

4) git commit -m "<传递你的注释>"

5) git远程添加来源“<传递你的项目克隆url>”

6) git pull——allow-unrelated-histories "<传递你的项目克隆url>" master

7) git push -u "<传递你的项目克隆url>" master

我也有同样的问题。确保你在正确的Heroku帐户。

当我试图把更改推到错误的Heroku账户时出现了。

我有这个错误,这是因为服务器上有更新,但Sourcetree没有显示任何可用的更新(可能是因为我离线时,它最后一次检查)。所以我在源树中做了刷新,现在它显示了两个项目,而不是一个项目。

所以,如果你得到这个错误,一定要按刷新或拉取,然后再试一次。