svn迁移到git实践

为什么要用git而不是svn

从使用者角度分析:
1.svn下载源代码慢。在git中一个几个G的版本库,一般一二十分钟就能下载完毕,但是在svn中要一个小时左右;
2.svn随时都得要与服务器交互,无论是查看log,还是查看以往的版本你必须跟服务器相连,并且速度奇慢务必,而git做这些几乎是瞬间的事;
3.各个分支之间的补丁迁移麻烦,在git上只要两三个命令就可以完事的(其实一个命令,因为需要查找与分支切换),但是在svn上你必须要下载每个分支的代码,然后比较修改,再上传;
4.git查看历史版本速度快,并且不需要联网。svn必须跟服务器相连才能取得版本,并且取版本非常慢;
5.git自带有优化过的grep,使得查询相关字符串的效率大大提高.

从服务器角度说为什么要用git:
1.git版本库占用空间小(几乎是svn的分支数之一也就是说如果有四个分支,svn的版本库的体积将接近git的四倍),SVN每个分支都是一份代码的copy,而git每个分支只是各个提交点的hash值的集合。分支几乎不占用什么空间;
2.git是分布式管理系统,完全可以不对代码进行备份,但SVN不行,一旦服务器的硬盘挂掉整个代码库就完了;
3.git不用时时联网查询,并且对文件进行压缩,使得文件体积大大减小,并且传输速度快,svn是单个文件,git是压缩后的,在使用svn时我已经碰到过好几次服务器无响应了。由于git很多都可以在本地操作的,所以大大降低了客户端对服务器的连接,出现这种情况的概率会大大减小;
4:如果客户端离服务器端非常远,在网速糟糕的情况下,用svn下载代码速度远不上git.




=============================================================================================================


由于先前是用SVN做代码的版本管理,现在需要尝试将SVN转到Git来,由于Git自身附带了高质量的转换工具,剩下我们就需要做好迁移的配置。Git自带的桥接命令git svn 可以与svn交互,这样并不完美,不如一次性把它做好,特此记录下迁移的过程。

利用git svn clone 命令先克隆一个仓库出来

  
  
git svn clone https://localhost:8443/svn/eimaya/ --authors-file=user.txt --no-metadata --trunk=trunk eimaya

本地的SVN地址为https://localhost:8443/svn/eimaya/ 或者 http://Arthur-PC:8080/svn/eimaya

authors file 是建立SVN用户到Git作者的一个映射关系,创建user.txt文件,用如下格式表示映射关系:

svn = Matt <blog@xbc.me>

svn 是我建立的SVN的用户,你需要建立你自己的用户映射关系。

no metadata 参数是阻止git 导出svn包含的附加信息,这样提交到Git的记录就会显得很“干净”。

–trunk 导出trunk分支。

eimaya 是你的project名称。

在导入的过程中出现下面的错误

  
  
Initialized empty Git repository in e:/git/test/eimaya/.git/ error 0: REPORT request failed on '/svn/eimaya/!svn/vcc/default': Path 'http://Arthur-PC:8080/svn/eimaya' is not canonicalized; there is a problem with the client. at D:\Git/libexec/git-core/git-svn line 5162

修改你的SVN 地址如下

http: //localhost: 8080 /svn /eimaya /

主要是git对https支持不好,更换为http即可。

输入命令导入svn仓库

git svn clone http: //localhost: 8080 /svn /eimaya / --authors-file=user.txt --no-metadata --trunk=trunk eimaya

如果出现以下错误

  
  
Initialized empty Git repository in e:/git/test/eimaya/.git/ W: +empty_dir: branches W: +empty_dir: tags W: +empty_dir: trunk Author: VisualSVN Server not defined in user.txt file

添加VisualSVN Server用户到user.txt 即可

VisualSVN Server = Matt <blog@xbc.me>

清理奇怪的标签,移到标签,将奇怪的远程分支变成实际的标签,把剩下的分支移到本地。

cp -Rf .git /refs /remotes /tags /* .git /refs /tags /
rm -Rf .git /refs /remotes /tags

然后把refs/remotees下面剩下的索引变成本地分支:

cp -Rf .git /refs /remotes /* .git /refs /heads /
rm -Rf .git /refs /remotes

添加远程git服务器地址

git remote add origin git @www.xbc.me:blog.git

推送全部的分支和标签

git push origin --all


==============================================================================

服务端用的是windows版gitblit,svn版本上的分支一律不保留

1、先登录gitblit管理页面,创建仓库 abc.com

2、在本地www目录下用git bash执行 git svn clone http://svn.com/abc/trunk --no-metadata abc ,结束后www目录下会多出一个名为abc目录,注意那个trunk目录,也可以是trunk下的子目录

3、进入abc目录,用git bash执行 git remote add origin http://git.com/abc.git

4、进入abc目录,用git bash执行 git push origin --all

回到gitblit管理页面,刷新就可以看到svn上的提交历史都转到git上了

可以叫其它成员 git clone http://git.com/abc.git 了


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值