一、安装subversion
安装SVN命令:
sudo yum install subversion
查看SVN安装目录:
which svnserver # 或者
rpm -ql subversion
查看版本信息:
svnserve --version
输出信息如下:
$ svnserve --version
svnserve, version 1.7.14 (r1542130)
compiled Apr 11 2018, 02:40:28
Copyright (C) 2013 The Apache Software Foundation.
This software consists of contributions made by many people; see the NOTICE
file for more information.
Subversion is open source software, see http://subversion.apache.org/
The following repository back-end (FS) modules are available:
* fs_base : Module for working with a Berkeley DB repository.
* fs_fs : Module for working with a plain file (FSFS) repository.
Cyrus SASL authentication is available.
二、修改数据根目录(未用到)
subversion默认以/var/svn作为数据根目录,可以通过修改/etc/sysconfig/svnserver修改默认位置:
# vim /etc/sysconfig/svnserve
// 找到OPTIONS配置
OPTIONS="-r /var/svn"
比如我将其修改为:
OPTIONS="-r /opt/svn"
接着启动svn服务的命令为:
systemctl enable svnserve
systemctl start svnserve
三、创建并配置版本库
3.1 创建版本库
创建用于存放版本库的目录,比如准备在/opt/svn目录下创建版本库,则首先创建svn目录:
mkdir -p /opt/svn
接着创建svntest目录:
mkdir -p /opt/svn/svntest
再接着创建svntest版本库:
svnadmin create /opt/svn/svntest
创建完成后,svntest版本库目录下会生成一些文件:
# ll
total 16
drwxr-xr-x. 2 root root 51 Jun 12 20:53 conf
drwxr-sr-x. 6 root root 4096 Jun 12 21:08 db
-r--r--r--. 1 root root 2 Jun 12 20:45 format
drwxr-xr-x. 2 root root 4096 Jun 12 20:45 hooks
drwxr-xr-x. 2 root root 39 Jun 12 20:45 locks
-rw-r--r--. 1 root root 229 Jun 12 20:45 README.txt
3.2 配置版本库
进入新建版本库的conf目录,可以看到如下文件:
- authz是权限控制文件;
- passwd是帐号密码文件;
- svnserve.conf是SVN服务器配置文件。
- 配置用户名密码
可以先在passwd文件中加入用户,格式是“用户名=密码”,比如:
admin=admin
guest=guest
- 配置用户权限
修改authz文件,添加用户权限,读为r,写为w。比如:
admin=rw
guest=r
版本库的目录格式(方括号格式)可以有如下几种形式:
- [/]:表示根目录(svnserve启动指定的目录),对全部版本库设置权限;
- [repos:/]:表示对版本库repos设置权限;
- [repos:/sadoc]:表示对版本库repos中的sadoc项目设置权限;
- [repos:/sadoc/oldboy]:表示对版本库repos中的sadoc项目中的oldboy目录设置权限。
配置权限的主体可以是用户、用户组或*,用户组需在前面加@,*表示全部用户。
用户权限可以是w、r、rw或空,空表示没有权限。authz每个参数都要顶格写,不能有空格。
最后修改SVN服务器配置:
anon-access=none # 不允许匿名用户访问
auth-access=write # 通过验证的用户可以读写
password-db=passwd # 用户与密码对应数据保存文件在passwd文件中
authz-db=authz # 权限信息保存在authz文件中
realm=/opt/svn/svntest # 指定认证域,即当前仓库的地址;可不用配置
注意:上面的svnserve.conf配置文件的配置顶格不能有空格!
四、启动SVN版本库
启动SVN服务的命令:
svnserve -d -r /opt/svn
停止SVN服务的命令:
killall svnserve
查看SVN服务:
ps -ef | grep 'svnserve'
五、打开端口服务
SVN服务的默认端口是3690,CentOS7系统对权限等级和安全等级要求比较高,默认情况下3690端口是关闭的,可以使用下面命令打开对应的端口:
# 查询3690端口状态
firewall-cmd --permanent --query-port=3690/tcp
# 添加3690端口用就开放
firewall-cmd --permanent --zone=public --add-port=3690/tcp
# 重启防火墙/加载配置
firewall-cmd --reload
六、访问SVN服务
正常启动SVN服务之后,在Windows端通过svn://ip/svntest即可访问新创建的仓库了,弹出窗口输入用户名和密码即可。
在Windows下,可以使用很多可视化工具对修改进行添加和提交,这里就不再累述了。
在Linux下,可通过下面命令来访问:
svn co svn://ip/svntest # co :chechout
在Linux下,添加和提交命令如下:
svn add /data/doc/file # 多个文件或目录,使用空格分开
svn commit -m "这里是注释"
svn ci -m "add file" /data/doc/file # ci :commit
其他SVN的常用命令:
svn st|status # 查看状态,列出修改的文件
svn resolved # 解决冲突
svn cleanup # 解除锁定
七、SVN转Git
7.1 环境准备
安装git-svn:
yum install -y git-svn
7.2 创建帐号映射
创建SVN帐号到Git帐号的映射文件users.txt,格式如下:
svn帐号=git帐号
7.3 执行转换
执行下面命令将SVN仓库转换为Git仓库:
git svn clone svn://ip端口/projectname --no-metadata --authors-file=users.txt --trunk=trunk projectname
如果不行的话,可以只执行下面命令:
git svn clone svn://ip端口/projectname --no-metadata --authors-file=users.txt projectname
7.4 添加远程Git仓库
进入转换后的Git仓库,使用如下命令添加远程Git仓库地址:
git remote add origin [email protected]:root/projectname.git
7.5 提交/上传
使用下面命令将所有的SVN提交记录,提交到远程Git仓库中:
git push -u origin master
八、常见问题
8.1 认证失败
输入账号密码后,提示:
svn: Authorization failed
请仔细查看passwd文件的用户名和密码,以及authz文件权限;若还是不行,请将权限配置处的[/]修改为[\]再试试。