有没有办法从远程Git回购中只检索一个特定的提交,而不将其克隆到我的PC上?远程回购的结构与我的完全相同,因此不会有任何冲突,但我不知道如何做到这一点,我不想克隆那个巨大的存储库。
我是新来的,有什么办法吗?
有没有办法从远程Git回购中只检索一个特定的提交,而不将其克隆到我的PC上?远程回购的结构与我的完全相同,因此不会有任何冲突,但我不知道如何做到这一点,我不想克隆那个巨大的存储库。
我是新来的,有什么办法吗?
当前回答
我认为'git ls-remote' (http://git-scm.com/docs/git-ls-remote)应该做你想要的。不用用力,取或拉。
其他回答
如果请求的提交是在远程回购的pull请求中,你可以通过它的ID获得它:
# Add the remote repo path, let's call it 'upstream':
git remote add upstream https://github.com/repo/project.git
# checkout the pull ID, for example ID '60':
git fetch upstream pull/60/head && git checkout FETCH_HEAD
您可以简单地获取远程回购的单个提交
git fetch <repo> <commit-id>
在那里,
<repo>可以是一个远程回购名称(例如origin),甚至是一个远程回购URL(例如https://git.foo.com/myrepo.git) <commit- ID >是提交的ID
例如
git fetch https://git.foo.com/myrepo.git 0a071603d87e0b89738599c160583a19a6d95545
在获取提交(以及丢失的祖先)之后,您可以简单地用它签出
git checkout FETCH_HEAD
注意,这将使你进入“分离的头脑”状态。
# make sure you fetch from the origin first
$ git fetch origin
# view code at COMMIT_ID (abc123)
$ git checkout abc123
# bring only COMMIT_ID (abc123)
# to your branch
# assuming your branch is master
$ git checkout master
$ git cherry-pick abc123
# bring all changes up to
# COMMIT_ID (abc123) to your branch
# assuming your branch is master
$ git checkout master
$ git merge abc123
参考资料- https://unfuddle.com/stack/tips-tricks/git-pull-specific-commit/
在一个项目中,我们遇到了一个问题,所以我们必须恢复到某个提交。我们成功地使用以下命令:
git reset --hard <commitID>
我查了一下我的git repo
git pull --rebase <repo> <branch>
允许git为分支拉入所有代码,然后我对我感兴趣的提交进行了重置。
Git reset——hard <commit-hash>
希望这能有所帮助。