广告位联系
返回顶部
分享到

Git实现checkout远程tag的介绍

相关技巧 来源:互联网 作者:佚名 发布时间:2022-09-24 12:04:29 人浏览
摘要

拉取项目 执行命令git clone: 1 git clone git@github.com:secbr/nacos.git 查看远程tag 执行命令git tag: 1 2 3 4 5 6 7 appledeMacBook-Pro-2:nacos apple$ git tag 0.2.1 0.2.1-RC1 0.3.0 0.3.0-RC1 0.4.0 ... 此时可找到需要拉

拉取项目

执行命令git clone:

1

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

查看远程tag

执行命令git tag:

1

2

3

4

5

6

7

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名称。

checkout需要的tag

执行命令git checkout:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

(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命令可以查看当前的分支情况:

1

2

3

(base) appledeMacBook-Pro-2:nacos apple$ git branch

* (HEAD detached at 2.0.2)

  develop

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

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

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

checkout作为一个分支

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

1

2

3

4

5

6

7

8

9

10

(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作为一个分支,可以合并成一个命令:

1

2

(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。

添加远程仓库

1

(base) appledeMacBook-Pro-2:nacos apple$ git remote add tag-2.0.2 git@github.com:secbr/nacos.git

push并设置upstream

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

(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'.


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 : https://blog.csdn.net/wo541075754/article/details/118759685
相关文章
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计