【问题标题】:git push to remote master branchgit推送到远程master分支
【发布时间】:2012-07-25 17:38:36
【问题描述】:

我有一个远程和一个本地 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 的新手。
我做错了吗?

【问题讨论】:

标签: git


【解决方案1】:

manojlds 的回答是正确的,但了解远程仓库的目的可能会有所帮助。

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

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

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

【讨论】:

    【解决方案2】:

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

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

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

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

    【讨论】:

    • 我认为这对 OP 没有帮助,因为您在谈论一般的失误而不是解决他的问题。
    • 关于您的经验法则:我认为这是错误的。到了提交的时候,就提交。时期。没有其他的。当需要将内容回放到另一个 repo 中时,您必须执行 fetchrebasepull 或类似的操作。然后解决冲突。然后push。在第 3 步中,您的本地 commits 被发送到远程仓库。 SVN 不可能是痛苦的,它一个。
    【解决方案3】:

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

    最好将您推送到的远程仓库设置为裸仓库 (git init --bare)。

    【讨论】:

    • 我现有的存储库可以设置为裸存储库(git init --bare)吗?
    • 我不这么认为,但如果它是一个基于 linux 的主机并且你的 repo 被命名为“foo”,那么它就像这样简单:mv foo foo2mkdir foo、@987654324 @、git init --baregit remote add origin ./../foo2git pull
    猜你喜欢
    • 2015-08-14
    • 2020-09-16
    • 2011-09-10
    • 2016-07-08
    • 2016-01-23
    • 2016-11-13
    • 1970-01-01
    • 2018-12-03
    • 1970-01-01
    相关资源
    最近更新 更多