https://www.atlassian.com/git/tutorials/syncing/git-fetch

Syncing

svn使用单个中央库来作为开发者之间沟通的桥梁,而协同合作是通过在开发者和中央库之间传递changeset来实现的。这种情况对于GIT的协同模型是有区别的,在git下每一个开发者都拥有他们自己的整库copy。取而代之于从working copy来提交变更集到一个中央库中,git允许你在不同的repo之间分享整个分支。

下面的命令允许你管理你和其他repo之间的连接,通过push 一个分支到其他的repo你实现发布本地history,通过pull一个branch到你自己的repo来获取他人的contribution.

Git remote

git remote命令允许你来create,view和delete和其他repo的connections. Remote connections可以这样来理解: 他们更像是bookmarks,而不是其他repo的直接连接。

例如,下面的图显示两个remote connections,一个是从你的repo到central repo,而另一个则是你和John的repo的连接

常用命令: git remote -v/git remote add <name> <url>/git remote rm <name>/git remote rename <old-name> <new-name>

注意:

git设计的目标是它会给每一个开发者一个完全独立的开发环境。这意味着信息并不会自动地在repo之间自动流转。相反地,开发人员需要手工的pull upstream commits来获取到local repo中,或者手工地push local commits到central repo.这个git remote命令实际上仅仅是一种传递URL的方便方法到这些sharing目的的commands.

Origin Remote

当你通过git clone来clone一个repo时,git会自动地创建一个被称为origin的remote connection指向到被cloned的repo.这对于开发者创建central repo的一份拷贝是非常方便的,因为这为开发者提供一种便捷pull upstream changes或者publish local commits的方法。这种行为也是为什么大多数git-based项目称他们的中央库为origin的原因。

Repository URLs

Git提供很多种方法去引用一个remote repo.两种最简单的方式是HTTP或者SSH.

HTTP方法是一种非常简单的允许匿名只读访问repo的方式,比如

http://host/path/to/repo.git

但是,通常是不允许push commit到一个http地址url上面的。需要读写一个repo,你必须使用ssh方式:

ssh://user@host/path/to/repo.git

你必须要有一个在host machine上的合法ssh帐号。

除了origin,创建一个连接到你的同事的repo上去的连接也是非常必要和方便的。比如,如果你的搭档John,维护了一个可以公开访问的repo在dev.example.com/john.git这个url的话,你可以通过过下面的命令增加一个connection

git remote add john http://dev.example.com/john.git

有了上面这种访问其他开发者的repo的简单方式后,这就允许人们绕开central repo来私下协同。这种模式对于小团队做大项目时是非常有用和高效的!!

git fetch

git fetch这个命令从一个remote repo来向你的local repo导入commits。这些commits导入后的结果是他们被保存在一个remote branch,而不是local branch上。这种模式就让你在集成remote commit之前来评审这些变更有了机会!

git fetch <remote> <branch>

Fetching这个动作完成的是当你希望查看其他人的工作时需要做的工作。既然被fetched的content是以一个remote branch来呈现的,那么这个动作对于你的local dev是没有任何影响的。这也就是说fetching是一个在外部变更落地前来review评审的安全的方法。

Remote branch

Remote branch和local branch是类似的,不过remote branch是代表着是来自于其他人的repo的commit。你可以像checkout一个local branch一样来checkout一个remote branch,但是这样做你将被置入detached HEAD state(就像checkout一个old commit一样的效果)。你可以把他们想象成一个read-only的分支。要想查看有哪些remote branches,只需要git branch -r命令参数即可。remote branch总是冠之以remote connection name,所以你永远不会和本地branch搞混淆。比如,下面的代码片段展示了remote branch的情况:

git branch -r
# origin/master
# origin/develop
# origin/some-feature

你可以通过git checkout origin/develop;git log来查看这些remote分支上有了哪些commit改动。如果你确认这些commit可以进到你的local branch上的话,你只需要git merge即可。

所以,对于git来说,你需要本地和远程的remo同步的话,你需要有两步:1.fetch,2.merge

而git pull则一步完成了上面的两个工作。

最新文章

  1. 你真的会玩SQL吗?删除重复数据且只保留一条
  2. Mac下github项目检出与提交
  3. viewpager和fragment预加载的解决
  4. 【现代程序设计】homework-09
  5. ORA-15177: cannot operate on system aliases (DBD ERROR: OCIStmtExecute)
  6. Windows下安装和配置Maven的方法及注意事项
  7. android 34 ListView进阶
  8. MEF初体验之五:Lazy Exports
  9. ubuntu15.10 安装 virtualbox5.0
  10. PHP 5 Calendar 函数
  11. JavaScript(二、BOM 浏览器对象模型)
  12. Object.freeze(); 方法冻结一个对象。
  13. appium+python3+pycharm踩得坑
  14. 爱上python之盲注探测脚本
  15. js 暂时存储 sessionStorge
  16. 关于EasyUI查询功能的二级联动
  17. 数位dp讲解及模板
  18. Python3安装配置【转】
  19. cadence allegro 布线时添加过孔
  20. time,sys,os 模块

热门文章

  1. readonly与disable
  2. selenium 多窗口(windows)及ITargetLocator使用总结
  3. 如何使用新的glibc来编译自己的程序
  4. vue过渡效果
  5. IE浏览器报Promise未定义
  6. k8s architecture
  7. Java入门系列-24-实现网络通信
  8. Spring 跨域请求
  9. 兼容ie6的ul水平居中对齐
  10. BEM样式使用规范