在下面的代码中,我需要一些关于克隆的信息
有一个由命令
创建的主回购 mkdir git_repo
cd git_repo
git init --bare //creates empty repo
然后用户将克隆git_repo
git clone git_repo user_repo
用户将再次克隆新的创建备份
git clone user_repo user_bk
cd user_bk
//user will edit an existing file and commit it
git push origin master
Counting objects: 5, done.
Delta compression using up to 8 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 294 bytes, done.
Total 3 (delta 0), reused 0 (delta 0)
Unpacking objects: 100% (3/3), 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 to
remote: error: 'ignore' or 'warn' in the remote repository to allow pushing into
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 some
remote: error: other way.
remote: error:
remote: error: To squelch this message and still keep the default behaviour, set
remote: error: 'receive.denyCurrentBranch' configuration variable to 'refuse'.
To user_repo
! [remote rejected] master -> master (branch is currently checked out)
error: failed to push some refs to 'user_bk'newtest by user
我的问题是
1.在git中我们可以签到克隆的reporsitory
2.如果必须这样做,那么它是如何完成的
3.如何解决上述错误情况
答案 0 :(得分:2)
转到user_repo然后:
git config --local --add receive.denyCurrentBranch ignore
然后你就可以做你尝试过的事了。 但是,建议不要按照打印输出中的说明进行操作。为什么要在备份中提交内容?使用git clone --bare来代替创建备份。
答案 1 :(得分:1)
您不应该推送到非裸存储库。创建备份存储库时,只需使用git clone --bare
即可。
答案 2 :(得分:0)
1.我们可以推送克隆存储库。为此,请在.git目录中正确配置.config文件 你得到的错误是“分支目前正在检出”。在这里,您将推送到master分支上的远程存储库,该存储库在远程端检出。结帐差异。使用git checkout branchname在远程分支,然后再次推送。