centos下搭建svn服务器

安装SVN

官网下载:http://subversion.apache.org/packages.html
SVN客户端:TortoiseSVN,官网下载:http://tortoisesvn.net/downloads.html

服务器端采用yum安装

yum install subversion

新建一个目录用于存储SVN所有文件

mkdir /svn

新建一个资源仓库

svnadmin create /svn/project
ls /svn/project/

conf db format hooks locks README.txt
目录用途说明:

  • hooks目录:放置hook脚本文件的目录
  • locks目录:用来放置subversion的db锁文件和db_logs锁文件的目录,用来追踪存取文件库的客户端
  • format文件:是一个文本文件,里面只放了一个整数,表示当前文件库配置的版本号
  • conf目录:是这个仓库的配置文件(仓库的用户访问账号、权限等)

配置svn服务的配置文件svnserver.conf文件

vim /svn/project/conf/svnserve.conf
[general]
anon-access = none
auth-access = write
password-db = /svn/project/conf/passwd
authz-db = /svn/project/conf/authz
realm = My Test Repository  #这是个提示信息

anon-access = none # 使非授权用户无法访问
auth-access = write # 使授权用户有写权限
password-db = passwd # 指明密码文件路径
authz-db = authz # 访问控制文件
各语句都必须顶格写, 左侧不能留空格, 否则会出错

添加两个访问用户及口令

vim /svn/project/conf/passwd
[users]
xiaoran.shen = 123456
test1 = 123456
test2 = 123456

注意:对用户配置文件的修改立即生效,不必重启svn服务。

配置新用户的授权文件

vim /svn/project/conf/authz
[groups]
admin = xiaoran.shen,test1
user = test2 
 
[/]
@admin = rw
@user = r
* =

格式说明:
版本库目录格式:
[<版本库>:/项目/目录]
@<用户组名> = <权限>
<用户名> = <权限>
/ 表示对根目录(即/svn/project目录)下的所有子目录范围设置权限
[/abc] 表示对资料库中abc项目设置权限
创建一个admin组,组成员包括xiaoran.shen和test1
创建一个user组,成员只有test2
admin组对目录有读写权限
单个用户test2有读写权限
*=表示除了上面设置的权限用户组以外,其他所有用户都设置空权限,空权限表示禁止访问本目录,这很重要一定要加上。
注意:对权限配置文件的修改立即生效,不必重启svn。

启动svn服务

svnserve -d -r /svn/project/

注意:不要使用系统提供的 /etc/init.d/svnserve start 来启动,因为系统默认的启动脚本中没有使用 –r /svn/project参数指定一个资源。这种情况下启动的svn服务,客户端连接会提示“svn: No repository found in ‘svn://192.168.11.229/project’ ”这样的错误。

若要使用/etc/init.d/svnserve 脚本,可以修改start()函数部分,如下:

start() {
	[ -x $exec ] || exit 5
	[ -f $config ] || exit 6
	echo -n $"Starting $prog: "
	daemon --pidfile=${pidfile} $exec $args -r /svn/project
	retval=$?
	echo
	[ $retval -eq 0 ] && touch $lockfile
	return $retval
}

服务器端搭建完成。

发表评论

电子邮件地址不会被公开。 必填项已用*标注