为什么我会收到“错误:无法推送一些参考”?

问题描述

| 我有一个远程git存储库和一个本地库。每当我在本地进行任何更改时,我都会将其推送到远程。然后我有时对远程文件执行“ git commit”以将更改存储在远程文件中。 我根本不直接编辑远程存储库。我只是提交更改。而且我是一个开发人员,没有其他人可以处理该存储库。 为什么从我所知道的错误中得知我必须先拉? 我不想拉,因为远程回购文件已过时,它将丢失我的本地更改。这真的很烦人,为什么会这样呢?以及如何在无需拉出或重新创建存储库的情况下进行修复? (如您所见,这有点像版本控制样式的颠覆类型) 编辑-错误
To ssh://...
 ! [rejected]        master -> master (non-fast-forward)
error: Failed to push some refs to \'ssh://...\'
To prevent you from losing history,non-fast-forward updates were rejected
Merge the remote changes (e.g. \'git pull\') before pushing again.  See the
\'Note about fast-forwards\' section of \'git push --help\' for details.
    

解决方法

您应该做的是将远程存储库创建为裸存储库。裸存储库只是git repo,没有当前签出(也就是说,它就像常规Git repo中
.git
dir的内容一样,因此它包含对象和refs,但没有索引或文件层次结构的工作副本)。如果您尝试推送到非裸存储库,则工作副本将与提交的内容不同步,并导致您在此处看到的各种问题。 您可以使用
git init --bare repo.git
创建一个裸仓库。或者,您可以使用
git clone --bare original-repo new-repo.git
将现有存储库克隆为裸存储库。 如果要在服务器上拥有存储库的已签出副本,则需要在服务器上创建一个新的非裸仓库,然后从推送到的裸仓库中拉入该仓库。     ,这总是意味着您没有将远程存储库与本地存储库同步,因此首先应使用命令git pull同步它们,如下所示:
git checkout master    
git pull origin master 
在此过程之后,您将对其进行同步,然后可以通过以下操作将更改推送到远程存储库:
git add [filename/directory]  
git commit -m\"input your message\"   
git remote add origin https://github.com//yourname.git     
git push origin master
    ,这是另一种选择。
git reset --mixed origin/master
git add .
git commit -m \"Your message\"
git push origin master
    ,我遇到了类似的问题,下面的命令起作用了。 git push --set-upstream原始主机