我已经设置了一个远程非裸机“主”存储库,并将其克隆到我的计算机上。我做了一些本地更改,更新了本地存储库,并将更改推回到远程存储库。当时一切都很好。

现在,我必须在远程回购中更改一些内容。然后,我在本地回购中更改了一些内容。我意识到不需要对远程回购进行更改。所以我尝试从本地回购机向远程回购机进行git推送,但出现了如下错误:

为了防止您丢失历史记录拒绝在再次推送之前合并远程更改。参见“注释”git push的“关于快进”部分--有关详细信息的帮助。

我想那可能是

git push --force

将强制我的本地副本将更改推送到远程副本并使其保持不变。它确实会强制更新,但当我返回到远程回购并提交时,我注意到文件包含过时的更改(主远程回购以前的更改)。

正如我在对其中一个答案的评论中提到的:

[一] 尝试强制,但当返回主服务器保存更改时,我得到了过时的暂存。因此,当我提交时,存储库并不相同。当我再次尝试使用git push时,我得到了同样的错误。

如何解决此问题?


当前回答

只要做到:

git push origin <your_branch_name> --force

或者如果您有特定回购:

git push https://git.... --force

这将删除您以前的提交并推送当前提交。

这可能不合适,但如果有人偶然发现这一页,认为他们可能需要一个简单的解决方案。。。

短标志

还要注意,-f是--force的缩写,因此

git push origin <your_branch_name> -f

也会起作用。

其他回答

使用以下命令:

git push -f origin master

首先,我不会直接对“主”回购协议进行任何修改。如果你真的想有一个“主”回购,那么你应该只推动它,而不是直接改变它。

关于您遇到的错误,您是否尝试过从本地回购中提取git,然后将git推送到主回购?你目前正在做的事情(如果我理解得很好的话)是强制推送,然后失去“主”回购中的更改。您应该首先在本地合并更改。

gitpush-force可以完成任务,尽管gitpush-foforcewithlease是一个更安全的命令

gitpush-force覆盖远程分支,而gitpush-foforce with lease仅在本地副本知道远程分支上的所有提交时才覆盖远程分支。这种差异使破坏其他人对项目的更改变得更加困难。

我真的建议:

仅推送至主回购确保主回购是一个裸回购,以避免主回购工作树与其.git库不同步。请参阅“How to push a local git repository to other computer?”如果您确实需要在主(裸机)存储库中进行修改,请克隆它(在主服务器上),进行修改并推回到它

换言之,保持可以从主服务器和本地计算机访问的裸回购,以便有一个从/从中提取/提取的上游回购。

只要做到:

git push origin <your_branch_name> --force

或者如果您有特定回购:

git push https://git.... --force

这将删除您以前的提交并推送当前提交。

这可能不合适,但如果有人偶然发现这一页,认为他们可能需要一个简单的解决方案。。。

短标志

还要注意,-f是--force的缩写,因此

git push origin <your_branch_name> -f

也会起作用。