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,处理方法,要在编辑器里打开文件,更改换行符保存,重新提交就可以了。