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工具

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

2.克隆代码

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

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

3.查看版本历史

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

另外有几个有意思的链接

基于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/

上一篇:【Alpha】第二次Scrum meeting


下一篇:Yii cookie操作