专栏首页donghui的博客在SVN仓库上使用Git 原

在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

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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 重启了下 Jenkins,踩到了一个深埋多年的坑

    业务方反馈,Jenkins 上某个 job 没有将 release 版本的组件发布到 maven 私服,以致依赖方无法引用依赖。

    donghui
  • Git LFS(Large File Storage)

    Git Large File Storage (LFS),是GitHub推出的基于Git的扩展,专门用来存储大文件。

    donghui
  • 使用Firefox的实时书签订阅Jenkins RSS来接收构建通知

    对于Jenkins的RSS构建通知,有Job级别的RSS构建通知和View级别的RSS构建通知:

    donghui
  • 开发中常用的一些知识检索链接(Markdown、SVN、Git等)

    子勰
  • 你可能不太会用的 10 个 Git 命令

    本文讨论的是开发人员、数据科学家或产品经理应该了解的各种 Git 命令。我们将了解该如何用 Git 进行检查、删除和整理操作。我们还将介绍如何用 Bash 别名...

    Spark学习技巧
  • ​你可能不太会用的10个Git命令

    如果你不熟悉基本的 git 命令,在阅读本文前可以先参考我之前写的关于 Git 工作流程的文章。

    机器之心
  • Git的增改查删

    Windows系统:在官网直接下载https://git-scm.com/downloads,安装即可

    腾讯工蜂
  • Git 撤销更改

    正常提交过程有三个步骤四个区和五种状态,下面就分别从这些入手,来看下 Git 撤销更改的方法。

    用户1065635
  • git指南--我想xxx,该用什么命令?

           git checkout -- xx 从暂存区取出到工作区,git add的逆操作

    rek
  • 获得一个Git仓库

    既然我们现在把一切都设置好了,那么我们需要一个Git仓库。有两种方式可以得到它:一种是从已有的Git仓库中 clone(克隆,复制);还有一种是新建一个仓库,把...

    用户3004328

扫码关注云+社区

领取腾讯云代金券