繁体   English   中英

git 推送远程repo

[英]git push remote repo

我的 flash 驱动器上有一个本地工作副本存储库和一个远程存储库。 我以前推过闪存驱动器,但我似乎不能再这样做了。

在这里,我进入了我的闪存驱动器上的远程仓库,看看我在哪个分支上并查看了日志。 然后我回到我的工作副本本地仓库,编辑了一个文件,添加了该文件,提交并尝试将它推送到我的闪存驱动器,但它没有工作。 谁能告诉我我做错了什么?

David-Adamss-MacBook-Pro:~ davidadams$ cd /volumes/thumbdrive/repo/releventz
David-Adamss-MacBook-Pro:releventz davidadams$ git status
# On branch master
# Your branch is ahead of 'origin/master' by 2 commits.
#
nothing to commit (working directory clean)
David-Adamss-MacBook-Pro:releventz davidadams$ git branch
* master
David-Adamss-MacBook-Pro:releventz davidadams$ git log
commit 65328c9603f62b7a2058f38fb441605b0c4c431e
Author: David Adams <adams.david.10@gmail.com>
Date:   Wed Jun 29 23:30:40 2011 -0500

    third commit

commit b3883fa933609db634b98d747299c1e9c96e8269
Author: David Adams <adams.david.10@gmail.com>
Date:   Wed Jun 29 23:10:53 2011 -0500

    second commit

commit 54832381a6fe898408c9e07bc8409a2982ec6274
Author: David Adams <adams.david.10@gmail.com>
Date:   Wed Jun 29 22:20:04 2011 -0500

    changed checklist.php

commit 1955664689313a589543576477e0a134f26cc313
Author: David Adams <adams.david.10@gmail.com>
Date:   Wed Jun 29 22:12:53 2011 -0500

    first releventz commit
David-Adamss-MacBook-Pro:releventz davidadams$ cd
David-Adamss-MacBook-Pro:~ davidadams$ cd
David-Adamss-MacBook-Pro:~ davidadams$ cd /applications/mamp/htdocs/releventz
David-Adamss-MacBook-Pro:releventz davidadams$ git status
# On branch master
nothing to commit (working directory clean)
David-Adamss-MacBook-Pro:releventz davidadams$ git status
# On branch master
# Changes not staged for commit:
#   (use "git add <file>..." to update what will be committed)
#   (use "git checkout -- <file>..." to discard changes in working directory)
#
#   modified:   application/libraries/calendarclass.php
#
no changes added to commit (use "git add" and/or "git commit -a")
David-Adamss-MacBook-Pro:releventz davidadams$ git add .
David-Adamss-MacBook-Pro:releventz davidadams$ git status
# On branch master
# Changes to be committed:
#   (use "git reset HEAD <file>..." to unstage)
#
#   modified:   application/libraries/calendarclass.php
#
David-Adamss-MacBook-Pro:releventz davidadams$ git commit -m 'blah blah'
[master 853232d] blah blah
 1 files changed, 1 insertions(+), 1 deletions(-)
David-Adamss-MacBook-Pro:releventz davidadams$ git push flashdrive master
Counting objects: 17, done.
Delta compression using up to 2 threads.
Compressing objects: 100% (12/12), done.
Writing objects: 100% (12/12), 1.89 KiB, done.
Total 12 (delta 8), reused 0 (delta 0)
Unpacking objects: 100% (12/12), done.
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'.
gTo /volumes/thumbdrive/repo/releventz
 ! [remote rejected] master -> master (branch is currently checked out)
    error: failed to push some refs to '/volumes/thumbdrive/repo/releventz'

您不能推送到另一个已签出代码的存储库。 Git 拒绝更新它。

如果您确实需要 flash 驱动器上的备份存储库,并且您永远不会在其中编辑内容,那么请将其设为裸存储库。

如果您将它用作编辑内容的第二个位置,则将 go 放入该存储库并从基于磁盘的存储库中提取。 IE,总是入一个积极使用的存储库,从不推送。

[是的,你可以解决这个问题,但你不应该]

今天我遇到了同样的错误。我用比尔门的回答这样的方法来修复它。 也许你可以这样做:

David-Adamss-MacBook-Pro:~ davidadams$ cd /volumes/thumbdrive/repo/releventz
David-Adamss-MacBook-Pro:~ davidadams$ git checkout subbranch
David-Adamss-MacBook-Pro:~ davidadams$ cd /applications/mamp/htdocs/releventz
David-Adamss-MacBook-Pro:~ davidadams$ git push flashdrive master

另一种选择是在闪存驱动器上没有完整的非裸(甚至是裸)repo(因为它涉及确保在远程存储设备上正确复制了很多文件),而是拥有或更新bundle

git 捆绑包是一个文件(通过 USB 驱动器更容易复制)。
您可以从该文件中提取,以便在您需要的任何地方重新创建一个完整的存储库。
请参阅“ 如何同步两个 git 存储库”作为说明。

韦斯提供了两个很好的答案。 另一种解决方案是创建第二个分支。 Go 到您的源存储库并签出第二个分支。 您现在可以从您的工作存储库推送到主分支。

cd master_repo
git checkout -b stepaside
cd work_repo
git push

您可以替换的后续推送

cd master_repo
git checkout stepaside
cd work_repo
git push

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM