git与svn, tfs等源代码管理器的协同

简单地说,这三个都是业界知名的源代码管理器。他们是有区别的,根本的区别在于git是分布式源代码管理器(每个本地都有完整的代码,及历史),而svn和tfs是集中式源代码管理器(只有服务器才有完整的历史,客户端本地只有最新版本)。git的作者是linux的作者(liuns),他当年就是因为无法忍受svn的集中式源代码管理才发明了git。

git风靡全球已经有些年头了,很多原先老项目的源代码管理,都在逐渐迁移到git。

 

git-svn

git内置了与svn的双向桥接 请参考http://git-scm.com/book/en/v1/Git-and-Other-Systems-Git-and-Subversion

常见的命令如下

git svn init (初始化)

git svn clone(克隆)

git svn fetch (拉取代码)

git svn dcommit (提交到svn)

一般在提交之前,需要执行git svn rebase命令来获取最新

 

 

git-tfs

How to migrate from TFS to Git

http://gitstack.com/how-to-migrate-from-tfs-to-git/ 

 

1.安装gittfs工具

这个工具可以通过下面的地址下载到 https://github.com/spraints/git-tfs (这里也有完整的介绍)

但更好的安装方式应该是使用chocolatey https://chocolatey.org/,这工具很像Linux中的apt-get工具

image

2.克隆代码

然后通过git tfs clone命令可以克隆某个TFS的源代码仓库

image

3.查看版本历史

image

 

 

另外有几个有意思的链接

基于GitStack搭建Git中心服务器 http://shanewfx.github.io/blog/2012/05/03/git-server-based-on-gitstack/

迁移VSS版本库到Git http://shanewfx.github.io/blog/2012/05/09/migrate-from-vss-to-git/

posted @ 2016-02-15 10:47  陈希章  阅读(3917)  评论(1编辑  收藏  举报