Git学习 <day7>-同步新分支到自己的github
2016-08-04 23:52
330 查看
我在Github上fork了一个名为Telkom的项目,因为主人的github上当前只有master,dev,test三个分支,因此我fork完了之后,我的github也只有master,dev,test三个分支。
随后主人又创建了testA,testB,testC三个分支,我如何把这新创建的三个分支同步到我的github中去呢?
点击Setting按钮,在打开的页面底端可以看到
删除完毕后,可以看到我的github中已经没有Telkom这个项目了,接下来重新fork主人的Telkom项目。
先进入主人的Telkom项目主页,在点击
接下来就已经同步最新的Telkom到我自己的github中了:
可以看到所有的分支都已同步。
通过
添加主人的远程仓库。
可以看到当前我添加的远程主机除了我自己的github远程仓库(取名origin),还有主人的远程仓库(取名为staging)。
使用以下命令可以看到详细信息:
基于主人的testA分支创建本地分支testA。其中这个命令可以分解为以下2个命令:
(1)
创建本地分支:
(2)
拉取主人远程仓库staging的testB分支内容到我本地testB分支中:
将本地仓库的testA,testB,testC分支push到我的github远程主机上:
随后主人又创建了testA,testB,testC三个分支,我如何把这新创建的三个分支同步到我的github中去呢?
方式一:重新fork
点击Setting按钮,在打开的页面底端可以看到
Danger Zone,点击
Delete this repository,删除我fork的Telkom项目,这个操作相当于unfork,注意首先要进入到我github下的Telkom项目中,再进入Settings:
删除完毕后,可以看到我的github中已经没有Telkom这个项目了,接下来重新fork主人的Telkom项目。
先进入主人的Telkom项目主页,在点击
fork:
接下来就已经同步最新的Telkom到我自己的github中了:
可以看到所有的分支都已同步。
方式二:利用本地仓库
首先把我的github中的Telkom克隆到本地:git clone git@github.com:sarahzhouUestc/Telkom.git
通过
git branch看到本地克隆下来的Telkom项目只有master分支。当前我github上的分支是master,dev,test。我的策略是:把主人新建的testA,testB,testC分支分别拉取到本地仓库,然后再有本地仓库push到我的github,相当于拿本地仓库当个中转站。
➜ Telkom git:(master) git remote add staging git@github.com:oryjk/Telkom.git
添加主人的远程仓库。
➜ Telkom git:(master) git remote origin staging
可以看到当前我添加的远程主机除了我自己的github远程仓库(取名origin),还有主人的远程仓库(取名为staging)。
使用以下命令可以看到详细信息:
➜ Telkom git:(master) git remote -v origin git@github.com:sarahzhouUestc/Telkom.git (fetch) origin git@github.com:sarahzhouUestc/Telkom.git (push) staging git@github.com:oryjk/Telkom.git (fetch) staging git@github.com:oryjk/Telkom.git (push)
➜ Telkom git:(master) git fetch staging From github.com:oryjk/Telkom *[new branch] dev -> staging/dev *[new branch] master -> staging/master *[new branch] test -> staging/test *[new branch] testA -> staging/testA *[new branch] testB -> staging/testB *[new branch] testC -> staging/testC
➜ Telkom git:(master) git checkout -b testA staging/testA Branch testA set up to track remote branch testA from staging. Switched to a new branch 'testA'
基于主人的testA分支创建本地分支testA。其中这个命令可以分解为以下2个命令:
(1)
创建本地分支:
➜ Telkom git:(master) git checkout -b testB Switched to a new branch 'testB'
(2)
拉取主人远程仓库staging的testB分支内容到我本地testB分支中:
➜ Telkom git:(testB) git pull staging testB From github.com:oryjk/Telkom *branch testB -> FETCH_HEAD Already up-to-date.
将本地仓库的testA,testB,testC分支push到我的github远程主机上:
➜ Telkom git:(testA) git push origin testA Total 0 (delta 0), reused 0 (delta 0) To git@github.com:sarahzhouUestc/Telkom.git *[new branch] testA -> testA
相关文章推荐
- Git 学习笔记<分支管理> (三)
- Git学习 <day5>-分支
- git学习——<五>git分支
- Git学习使用(五):分支管理<Ⅰ>
- Git学习之基础<2>
- Git学习之基础<1>
- 自己编写的泛型List<T>代码,供大家学习,欢迎指导
- Git学习<二>文件修改和提交
- Git学习笔记之<撤销操作>
- RHCE学习<9>Rsync备份同步、NTP和Rsyslog日志管理
- Git学习笔记之<Git基础>
- git学习——<一>git安装
- Git学习--> 社区化协作以及分支操作
- pro git 学习<二>
- Git超级菜鸟学习--> 社区化协作以及分支操作
- Git 学习笔记<简介与安装> (一)
- 学习Timer类,定制自己的调度器<一>
- Git学习<二>文件修改和提交
- 使用git上传代码到github<一>
- git学习——<四>git版本管理