为什么要用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 地址如下
主要是git对https支持不好,更换为http即可。
输入命令导入svn仓库
如果出现以下错误
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>
清理奇怪的标签,移到标签,将奇怪的远程分支变成实际的标签,把剩下的分支移到本地。
rm -Rf .git /refs /remotes /tags
然后把refs/remotees下面剩下的索引变成本地分支:
rm -Rf .git /refs /remotes
添加远程git服务器地址
推送全部的分支和标签
==============================================================================
服务端用的是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 了