git-svn

git-svn用于Git和SVN的转换,可以把Git仓库迁移成SVN仓库,反之亦可。

详细介绍可见[1],或者命令行输入git-svn。

Bidirectional operation between a Subversion repository and git.

git svn can track a standard Subversion repository, following the common "trunk/branches/tags" layout,

with the --stdlayout option. It can also follow branches and tags in any layout with the -T/ -t/ -b options.

Once tracking a Subversion repository, the git repository can be updated from Subversion by thefetch

command and Subversion updated from git by the dcommit command.

Git迁移到SVN

把Git迁移到SVN?没错,还真有这种需求,虽然较少:)

Git has a feature to work with SVN repositories, git-svn, but that's intended to check out

existing code from SVN and work on it, not publishing an existing Git tree into a SVN repository.

(1) 依赖包

需要安装subversion-perl、perl-TermReadKey。

Git中带有git-svn,需要确定它的路径可在PATH中找到。

(2) 建立svn项目

在svn服务器中新建svn项目proj。

# svnadmin create proj

(3) svn项目的本地初次提交

# svn mkdir http://IP:PORT/svn/proj/trunk \

http://IP:PORT/svn/proj/branches \

http://IP:POPT/svn/proj/tags \

http://IP:PORT/svn/proj/docs -m "Initial import"

(4) 提交Git proj项目到SVN proj

进入Git proj项目。

# git-svn init -s http://IP:PORT/svn/proj // -s表示svn为标准布局

标准布局的意思就是:

trunk分支为:proj/trunk,可以用-T另外指定

branches分支为:proj/branches,可用-b另外指定

tags分支为:proj/tags,可用-t另外指定

# git-svn fetch // 获取SVN proj的更新

r1 = 79563196f21ce4699a04fa4ae24d0ca916bf3acf (refs/remotes/trunk)

trunk分支代表SVN proj的trunk分支

# git-svn dcommit // 提交Git proj的更新

注意!这个时候会报错:

Unable to determine upstream SVN information from HEAD history.

Perhaps the repository is empty. at /usr/local/git/libexec/git-core/git-svn line 852.

因为现在Git proj的commits不知道要放到SVN proj的哪个版本之后,即Git proj的这些提交要

放在SVN哪个版本之后(显然是放到SVN的初始提交之后,但是Git proj就是不知道,因为设计者

并不考虑把Git proj转为SVN proj的情况:)

以下是详细描述:

This fails since the git svn command can't figure out which commits to push: there's no link

between our original Git repository and the Subversion heads.

To fix this, we can use a Git graft to link them. We'll tell Git the commit which created the SVN

folder in which we want to store the project is the parent commit of the first commit in our Git

repository.

解决方法

# git show-ref trunk // 显示SVN proj trunk分支的HEAD,即r1

79563196f21ce4699a04fa4ae24d0ca916bf3acf refs/remotes/trunk

# git log --pretty=oneline master | tail -n 1 // 显示Git proj 的第一个commit

561c439a15f807b8d62551a0c64f939c15489899 initial import

# echo "561c439a15f807b8d62551a0c64f939c15489899 79563196f21ce4699a04fa4ae24d0ca916bf3acf" >> .git/info/grafts

把Git proj从561c43开始的提交,添加到SVN proj在795631之后的提交。

# git-svn dcommit // 提交Git proj的更新到SVN proj中

这个时候就把Git proj完整的转化成SVN proj,后者完全符合SVN的规范了。

(5) 把git分支提交到svn的分支

如果原来的git仓库不仅有master,还有其它分支,那么怎么把git的分支提交为svn的分支呢?

这个时候就要用到git rebase了。

过程如下:

在远端svn仓库中创建一个新分支。

# svn cp URL/trunk URL/branches/remote-branch

更新本端Git仓库。

# git-svn fetch

切换到本端的分支。

# git checkout local-branch

创建一个用于临时用的分支,其实和local-branch是一样的。

# git checkout -b temp-local-branch

关键点来了,把本端分支的所有修改,合并到远端分支。

# git rebase remotes/remote-branch

完成上一步以后,远端分支已经含有本端分支的所有commit。

接着可以把修改提交到svn仓库了。

# git svn dcommit

最后把本端的临时分支删除。

# git branch -D temp-local-branch

此时再查看svn仓库,就会发现branch/remote-branch已经是原来的git分支了。

不过svn分支的日志顺序,相较于原来git分支的可能会有所不同,这是由rebase引起的,正常现象。

(6) 从git分支更新svn分支

修改.git/config,添加远程分支:

[svn-remote "branch"]

url = URL/proj/branches/branch

fetch = :refs/remotes/branch

绑定本地分支和远程分支:

[branch "local-branch"]

remote = .

merge = refs/remotes/branch

修改了本地分支local-branch后,可以直接提交到远端svn的branch分支了。

# git-svn dcommit

SVN迁移到Git

相比之前介绍的Git迁移到SVN,SVN迁移到Git才是主流趋势,也更加容易,因为这是git-svn的主要目的。

同样用git-svn来完成迁移:

git-svn primarily can be used to checkout a Subversion repository to a local Git repo and then

push your changes back to the original Subversion repository.

克隆SVN仓库,可以使用-T trunk、-b branches、-t tags来指定对应分支,-s表示采用标准布局。

# git-svn clone -s URL/proj proj

相当于执行了git-svn init和git-svn fetch。

把SVN仓库的更新同步到Git。

# git-svn rebase

创建.gitignore文件。

# git-svn create-ignore

将Git的更新提交到SVN仓库。

# git-svn dcommit

Author

zhangskd @ csdn blog

Reference

[1]. https://www.kernel.org/pub/software/scm/git/docs/git-svn.html

[2]. http://plpatterns.com/post/234334879/how-to-convert-a-local-branch-in-git-to-a-remote

[3]. http://www.cnblogs.com/kym/archive/2010/08/12/1797937.html

GIT版本控制 — GIT与SVN的相互转换 (三)的更多相关文章

  1. Git版本控制 Git、github,gitlab相关操作

    目录 关于版本控制 版本管理工具 集中式管理 分布式管理 git版本管理 git介绍 软件安装 Git工作状态 原理流程步骤 git基本操作 对文件进行修改 分支 共享仓库 创建共享仓库: 共享仓库上 ...

  2. 图文详解 : 什么是版本控制?Eclipse配置SVN和IDEA配置GIT教程

    前言 虽然在工作中, VCS已然配置妥当, 我们敲好的业务只需要Commit&push提交就好, 但是不妨碍我们了解什么是版本控制, 为什么要使用这类工具? ps.最近项目里的小伙伴想在自己家 ...

  3. Git版本控制工具(三)----远程仓库GitHub的使用

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  4. 版本控制比较cvs,svn,git

    版本控制比较cvs,svn,git 几个重要概念: 版本库模型(Repository model):描述了多个源码版本库副本间的关系,有客户端/服务器和分布式两种模式.在客户端/服务器模式下,每一用户 ...

  5. 版本控制-Git服务器搭建和常用命令使用

    Git是目前世界上最先进的分布式版本控制系统(没有之一).使用Svn的请参考<版本控制-svn服务器搭建和常用命令(centos 6.3)>,下面介绍Git的常用命令 常用命令 简单版 升 ...

  6. Git版本控制与工作流

    基本概念 Git是什么? Git是分布式版本控制系统,与SVN类似的集中化版本控制系统相比,集中化版本控制系统虽然能够令多个团队成员一起协作开发,但有时如果中央服务器宕机的话,谁也无法在宕机期间提交更 ...

  7. git版本控制工具(二)----本地版本库的常用操作

    ​[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/ ...

  8. Git版本控制使用介绍

    Git是什么? Git是一款免费.开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目. Git与SVN的最主要的区别? Git是分布式的,SVN不是 Git没有一个全局的版本号,而SVN有 ...

  9. Git 版本控制工具(学习笔记)

    GIT(分布式) 一.Git 初始版本控制工具 1. 安装Git Ubuntu系统下,打开shell界面,输入: sudo apt-get install git-core  之后回车输入密码,即可完 ...

随机推荐

  1. 详解BLE连接建立过程

    同一款手机,为什么跟某些设备可以连接成功,而跟另外一些设备又连接不成功?同一个设备,为什么跟某些手机可以建立连接,而跟另外一些手机又无法建立连接?同一个手机,同一个设备,为什么他们两者有时候连起来很快 ...

  2. R语言使用 multicore 包进行并行计算

    R语言是单线程的,如果数据量比较大的情况下最好用并行计算来处理数据,这样会获得运行速度倍数的提升.这里介绍一个基于Unix系统的并行程序包:multicore. 我们用三种不同的方式来进行一个简单的数 ...

  3. Android Studio: You need to use a Theme.AppCompat theme (or descendant) with this activity.

    错误描述为: java.lang.IllegalStateException: You need to use a Theme.AppCompat theme (or descendant) with ...

  4. Bootstrap3 表单-基本表单

    单独的表单控件会被自动赋予一些全局样式.所有设置了 .form-control 类的 <input>.<textarea> 和 <select> 元素都将被默认设置 ...

  5. iOS开源加密相册Agony的实现(二)

    简介 虽然目前市面上有一些不错的加密相册App,但不是内置广告,就是对上传的张数有所限制.本文介绍了一个加密相册的制作过程,该加密相册将包括多密码(输入不同的密码即可访问不同的空间,可掩人耳目).Wi ...

  6. Android的Spinner控件用法解析

    微调框 微调框提供一种方法,让用户可以从值集中快速选择一个值.默认状态下,微调框显示其当前所选的值. 触摸微调框可显示下拉菜单,其中列有所有其他可用值,用户可从中选择一个新值. 您可以使用 Spinn ...

  7. 自定义progressDialog(数据加载框)的实现

    大家在开发客户端时基本上都需要获取数据,在获取数据时会有一个等待状态,这时我们可以利用系统自带的progressDialog来向用户展示"数据正在加载中..."等等,但有时我们会觉 ...

  8. 理解性能的奥秘——应用程序中慢,SSMS中快(4)——收集解决参数嗅探问题的信息

    本文属于<理解性能的奥秘--应用程序中慢,SSMS中快>系列 接上文:理解性能的奥秘--应用程序中慢,SSMS中快(3)--不总是参数嗅探的错 前面已经提到过关于存储过程在SSMS中运行很 ...

  9. Dynamics CRM 站点地图中URL的&号编码问题

    现在大多数人对站点地图的操作都通过工具来执行,但如果你使用原始的编辑XML方式,并且你的SubArea中对应的不是某个Entity而是一串URL时,要注意了你的URL中如果带有与符号即&,那就 ...

  10. EBS应收(AR)模块常用表

     select * from ar_batches_all 事务处理批 select * from ra_customer_trx_all INVOICE头 select * from ra_cu ...