我们在使用git进行开发的时候经常会遇到需要切换远程分支并且提交到远程指定分支的情况,现在记录下操作步骤。
查看远程所有分支
git branch不带参数,列出本地已经存在的分支,并且在当前分支的前面用*标记,加上-a
参数可以查看所有分支列表,包括本地和远程,远程分支一般会用红色字体标记出来
$ git branch -a
* dev
master
remotes/origin/HEAD -> origin/master
remotes/origin/master
remotes/origin/release/test
新建分支并切换到指定分支
git checkout -b dev origin/release/test
- git checkout -b 本地分支名 origin/远程分支名
该命令可以将远程git仓库里的指定分支拉取到本地,这样就在本地新建了一个dev分支,并和指定的远程分支release/test
关联了起来。
运行结果:
Switched to a new branch 'dev'
Branch 'dev' set up to track remote branch 'release/test' from 'origin'.
查看本地分支及追踪的分支
git branch -vv
命令可以显示本地所有分支,执行结果如下:
$ git branch -vv
* dev e67e3ef [origin/release/test]
master 11160c2 [origin/master: behind 5] Merge branch 'master' of https://xxxxxx/scm/join/yj-stat
- 表示当前所在分支,
[远程分支]
表示当前本地分支追踪的远程分支,最后一个是最近一次提交的注释。
将本地分支推送到远程
git push <远程主机名> <本地分支名>:<远程分支名>
例如:
$ git push -u origin dev:release/test
成功后显示如下:
Counting objects: 8, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (8/8), done.
Writing objects: 100% (8/8), 754 bytes | 754.00 KiB/s, done.
Total 8 (delta 6), reused 0 (delta 0)
remote:
remote: Create pull request for release/test:
remote: https://git.jointforce.com/projects/JOIN/repos/yj-stat/compare/commits?sourceBranch=refs/heads/release/test
remote:
To https://git.jointforce.com/scm/join/yj-stat.git
a22ed65..e8782b2 dev -> release/test
Branch 'dev' set up to track remote branch 'release/test' from 'origin'.
上述命令表示将本地dev分支推送到远程release/test
分支。