3

我有一个远程和一个本地 git 存储库。
本地存储库是从远程克隆的。
当我修改本地存储库并提交到主分支时。
然后我运行“ git push ”到远程存储库。
但它失败并输出以下消息。

remote: error: refusing to update checked out branch: refs/heads/master
remote: error: By default, updating the current branch in a non-bare repository
remote: error: is denied, because it will make the index and work tree inconsistent
remote: error: with what you pushed, and will require 'git reset --hard' to match
remote: error: the work tree to HEAD.
remote: error: 
remote: error: You can set 'receive.denyCurrentBranch' configuration variable t
remote: error: 'ignore' or 'warn' in the remote repository to allow pushing int
remote: error: its current branch; however, this is not recommended unless you
remote: error: arranged to update its work tree to match what you pushed in som
remote: error: other way.
remote: error: 
remote: error: To squelch this message and still keep the default behaviour, se
remote: error: 'receive.denyCurrentBranch' configuration variable to 'refuse'.

我在远程存储库中“git checkout -b current”另一个分支。
在我的本地存储库中,我运行“git push”然后它成功。
但是本地修改只推送到远程master分支。
然后我应该在远程存储库中运行“git merge master”来进行更改。

我是 git 的新手。
我做错了吗?

4

3 回答 3

7

远程存储库不是裸存储库,并且已签出主存储库。而且,默认情况下,git 不允许您推送到非裸仓库的已签出分支。

git init --bare理想情况下,您推送到的远程仓库应设置为裸仓库 ( )。

于 2012-07-27T03:38:10.037 回答
2

manojlds 的回答是正确的,但它可能有助于了解远程回购的目的是什么。

  • 如果远程存储库仅用于备份/协作目的->您的想法是正确的,只需将远程存储库替换为“裸”存储库,然后从那里开始。
  • 如果远程仓库是生产服务器,那么你做错了 -> 你应该有不同的配置。

一个很好的确认,以便您可以“推向生产”是让您的“裸”存储库用于备份/协作目的,然后您有一个单独的存储库,它在部署服务器上设置并从裸存储库克隆。然后在裸仓库上,您可以放置​​一个“接收后挂钩”,这会使部署仓库进行拉取。

我敢肯定有关于如何做到这一点的指南......我自己也跟着过一次:)

于 2012-07-27T05:53:42.597 回答
1

当我刚接触 github 时,我的导师给了我这个经验法则:

在本地修改您的代码。当需要提交时,请执行以下操作:

  1. git pull(将远程仓库的内部引用头同步到本地仓库非常重要)
  2. 如果不同文件中存在任何冲突,请通过在 Kdiff 中打开这两个文件来选择您的副本或远程副本或两者的混合,从而仔细合并它们。一旦你解决了所有的冲突,就会推动合并。
  3. 在第 2 步之后,请git push保存您对首先要提交的代码所做的本地更改。

颠覆可能会很痛苦,但保持同步非常重要。这些规则对我使用 github 维护子版本有很大帮助。希望这有帮助。

于 2012-07-27T04:24:33.673 回答