在SVN仓库上使用Git 原

2019-04-19 15:17:26 浏览数 (1)

最近在使用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

(adsbygoogle = window.adsbygoogle || []).push({});

0 人点赞