在SVN仓库上使用Git

最近在使用Git,切身体会到了Git在分支管理、离线开发的优越性,它可以在本地仓库为不同的任务创建不同的分支。
当你的仓库是SVN类型的,如果你想在本地使用Git进行版本控制,你可以使用git-svn。

安装git
如果没有安装git,可以从 http://git-scm.com/downloads下载安装。
git安装的时候会附带git-svn(建议安装最新版本)。

git-svn简单使用
1、克隆一个SVN仓库(相当于svn checkout)
git svn clone http://svn.example.com/project/trunk
2、进入到新克隆的目录下
cd trunk
3、当前所在的分支为master,可以使用git branch校验
git branch
4、在本地做修改,并提交到本地Git仓库
git add、git commit ……
5、更新SVN仓库(相当于svn update)
git svn rebase
6、提交修改到SVN仓库(相当于svn commit)
git svn dcommit

查看git-svn帮助文档
想要了解更多关于git-svn的使用,可以通过以下几种方式查看git-svn帮助文档:
  • git svn --help
  • git svn help
  • git help svn
  • git --help svn
或者可以查看 官网提供的帮助文档。

使用SourceTree
SourceTree 是 Windows 和 OS X 下免费的 Git 和 Hg 客户端。
经验证,SourceTree支持将SVN仓库克隆为Git仓库以及其他可以使用git-svn命令行进行的操作。

遇到的问题
git svn can't authenticate on svn:// repository
使用git svn clone -s svn://git.oschina.net/donhui/md-doc-with-pic时,报如下错误:
Authorization failed: Cannot negotiate authentication mechanism at /usr/lib/perl5/site_perl/Git/SVN.pm line 310

所使用的git的版本为:git version 1.9.5. msysgit.1

通过aol.com搜索,找到如下页面:
http://comments.gmane.org/gmane.comp.version-control.msysgit/17865
页面中有如下片段,从而得知这是个issue,而使用http(s)协议的svn仓库则正常:
This issue exists on several versions of msysgit, including latest 1.8.0-preview20121022 and 1.8.1-preview20130110.
Cygwin's version of git can fetch from this. 


参考:
http://git-scm.com/docs/git-svn/1.8.5
http://blog.chinaunix.net/uid-11639156-id-3077471.html
http://www.oschina.net/translate/howto_use_git_with_svn

你可能感兴趣的:(git)