Linux下CVS库迁移到SVN库攻略

转换步骤: 1、 CVS库要备份好(直接copy CVS模块的内容); 2、 SVN服务器要装好; 3、 CVS2SVN安装; 4、 转换后的测试。

安装软件的版本 cvs版本:1.12.12 svn版本:1.4.6

cvs2svn版本:2.3.0

下载:cvs2svn

安装:cd /usr/software

tar -zxf cvs2svn-1.2.1.tar.gz       cd cvs2svn-1.2.1       make install       make clean

使用cvs2svn的前提是linux系统必须安装好python。

使用cvs2svn把CVS档案库转换为SVN档案库,cvs2svn工具根据需要可以几种转换方式供选择的。默认的方式为完全转换,我们就是采用这样方式的。 进入csv2svn所在的目录:

./cvs2svn --svnadmin=/opt/svn/bin/svnadmin --encoding=UTF-8 --encoding=gbk --fs-type=fsfs -s /home/svn1 /var/cvs/liprojcet

加载到版本库指定的目录中,缺省加载到根

参数说明:

--svnadmin svndadmin的路径,创建SVN档案库时需要

--encoding 所采用的编码,默认为ascii,可加载多种编码类型    --fs-type  档案库的类型fsfs或bdb

-s         SVN档案库的位置,该命令会自动生成svn1的新库    最后一个是要转换CVS档案库的位置

如果cvs和svn服务器在不同电脑上,则需要使用2条命令,先生成dumpfile文件,copy到svn服务器上,再转换成svn库。

/cvs2svn --dumpfile=/var/cvs/dumpfile.txt --encoding=utf-8 --encoding=gbk --fs-type=fsfs  /var/cvs/liprojcet

/svnadmin load /opt/svn/svnroot/new_repos < dumpfile.txt new_repos必须是已经初始化的svn库

GB2312是GBK的子集,GBK是GB18030的子集 GBK是包括中日韩字符的大字符集合 如果是中文的网站 推荐GB2312 GBK有时还是有点问题 为了避免所有乱码问题,应该采用UTF-8,将来要支持国际化也非常方便 UTF-8可以看作是大字符集,它包含了大部分文字的编码。 使用UTF-8的一个好处是其他地区的用户(如香港台湾)无需安装简体中文支持就能正常观看你的文字而不会出现乱码。

测试内容: 1、 对文件夹进行比较,包括文本文件和二进制文件;

用Beyond compare对比liproject和从svn8库取下来的trunk,除了配置文件.CVS和.SVN外,其他的文件内容应一致。  2、 中文目录、中文文件夹、中文内容转换是否乱码;

可挑选一些设置了中文的目录、文件夹、文件内容查看一下。  3、 Branch、tag、trunk文件夹内容是否转换成功;

可用svn export 库文件到本地,查看Branch、tag下的内容,是否转换完全。  4、 文件编码格式;

在Linux中查看文件编码可以通过以下几种方式: 在Vim 中可以直接查看文件编码 /vim filename

:set fileencoding   即可显示文件编码格式。  5、 历史是否保留了。 /svn log

备注:.sln文件在转换后不能双击打开,因为linux 的换行符是\n,但windows通常是\r\n,处理方法,要在编辑器里打开文件,更改换行符保存,重新提交就可以了。