Git如何实现checkout远程tag(git如何撤回add)硬核推荐

随心笔谈2年前发布 admin
204 0 0

文章摘要

这篇文章主要介绍了如何在Git中进行远程仓库的分支管理和tag checkout操作。文章详细介绍了以下内容: 1. **克隆远程仓库**:通过`git clone git@github.com:secbr/nacos.git`将远程仓库克隆到本地。 2. **创建远程仓库的tag**:使用`git tag`命令创建远程仓库的各个tag版本,如0.2.1、0.3.0等。 3. **查看和切换到特定tag分支**:使用`git checkout`命令切换到特定的tag分支(如2.0.2),并解释了在切换到远程分支后如何管理本地提交。 4. **远程pull request问题**:当切换到远程分支后,本地提交成为匿名提交,无法追溯。解决方法是使用`git checkout -b tagName`新建本地分支并跟踪远程分支。 5. **远程分支设置**:在远程仓库上创建本地分支并设置为远程分支的upstream。通过`git push --set-upstream origin tagName`解决远程pull request时找不到 upstream 的问题。 文章通过具体示例详细说明了这些操作的命令和注意事项,帮助读者理解如何在远程仓库中进行有效的分支管理和提交操作。



目录拉取项目查看远程tagcheckout需要的tagcheckout作为一个分支添加远程仓库push并设置upstream

执行命令git clone:

git clone git@github.com:secbr/nacos.git

执行命令git tag:

appledeMacBook-Pro-2:nacos apple$ git tag
0.2.1
0.2.1-RC1
0.3.0
0.3.0-RC1
0.4.0

此时可找到需要拉取的tag名称。

执行命令git checkout:

(base) appledeMacBook-Pro-2:nacos apple$ git checkout 2.0.2
Note: switching to ‘2.0.2’.

You are in ‘detached HEAD’ state. You can look around, make experimental
changes and commit them, and you can discard any commits you make in this
state without impacting any branches by switching back to a branch.

If you want to create a new branch to retain commits you create, you may
do so (now or later) by using -c with the switch command. Example:

? git switch -c <new-branch-name>

Or undo this operation with:

? git switch –

Turn off this advice by setting config variable advice.detachedHead to false

HEAD is now at 1fac5c833 Merge pull request #6052 from alibaba/develop

其中2.0.2为tag(分支)名称。

通过git branch命令可以查看当前的分支情况:

(base) appledeMacBook-Pro-2:nacos apple$ git branch
* (HEAD detached at 2.0.2)
? develop

通过此种方式,获得的分支Head处于游离状态,我们可以很方便地在历史版本之间互相切换,比如需要回到某次提交,直接checkout对应的 commit id或者tag名即可。

但在这个基础上的提交会新开一个匿名分支!也就是说我们的提交是无法可见保存的,一旦切到别的分支,游离状态以后的提交就不可追溯了。

解决办法就是新建一个分支保存游离状态后的提交。

执行git checkout -b tagName (将tag checkout出去作为一个branch):

(base) appledeMacBook-Pro-2:nacos apple$ git checkout -b tag-2.0.2
Switched to a new branch ‘tag-2.0.2’
(base) appledeMacBook-Pro-2:nacos apple$ git branch
? develop
* tag-2.0.2
(base) appledeMacBook-Pro-2:nacos apple$ git checkout -b tag-2.0.2
Switched to a new branch ‘tag-2.0.2’
(base) appledeMacBook-Pro-2:nacos apple$ git branch
? develop
* tag-2.0.2

在游离状态下的tag中执行git checkout -b tag-2.0.2来新建一个分支。

当然上述checkout tag和checkout tag作为一个分支,可以合并成一个命令:

(base) appledeMacBook-Pro-2:nacos apple$ git checkout -b tag-1.4.2 1.4.2
Switched to a new branch ‘tag-1.4.2’

上述命令,将远程版本为1.4.2的tag,新建一个本地分支,名称为tag-1.4.2。

(base) appledeMacBook-Pro-2:nacos apple$ git remote add tag-2.0.2 git@github.com:secbr/nacos.git
(base) appledeMacBook-Pro-2:nacos apple$ git push
fatal: The current branch tag-2.0.2 has no upstream branch.
To push the current branch and set the remote as upstream, use

? ? git push –set-upstream origin tag-2.0.2

(base) appledeMacBook-Pro-2:nacos apple$ git push –set-upstream origin tag-2.0.2
Total 0 (delta 0), reused 0 (delta 0), pack-reused 0
remote:
remote: Create a pull request for ‘tag-2.0.2’ on GitHub by visiting:
remote: ? ? ?https://github.com/secbr/nacos/pull/new/tag-2.0.2
remote:
To github.com:secbr/nacos.git
?* [new branch] ? ? ? ? ?tag-2.0.2 -> tag-2.0.2
Branch ‘tag-2.0.2’ set up to track remote branch ‘tag-2.0.2’ from ‘origin’.

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。 

您可能感兴趣的文章:Git 常用命令清单(整理且详细)git分支(branch)操作相关命令及分支命令的使用Git科普文,Git基本原理及各种骚操作(推荐)

© 版权声明

相关文章