Linux 上搭建SVN 服务器

#Linux搭建SVN 服务器
###一、安装SVN
官网下载:http://subversion.apache.org/packages.html
SVN客户端:TortoiseSVN,官网下载:http://tortoisesvn.net/downloads.html
##yum install subversion
新建一个目录用于存储SVN所有文件
##mkdir /svn
新建一个资源仓库
svnadmin create /svn/project

ls /svn/project/

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

vi /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 #这是个提示信息
保存
4. 添加两个访问用户及口令

vi /svn/project/conf/passwd

[users]
xiaoran.shen = 123456
test1 = 123456
test2 = 123456
保存
注意:对用户配置文件的修改立即生效,不必重启svn服务。
5. 配置新用户的授权文件

vi /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。
  1.   启动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’ ”这样的错误。
默认svn服务器端口是3690。
杀死svn服务:

ps -ef|grep svn

root 4642 1 0 16:08 ? 00:00:00 svnserve -d -r /svn/project/
root 4692 3676 0 16:13 pts/2 00:00:00 grep svn

kill -9 4642

若要使用/etc/init.d/svnserve 脚本,可以修改start()函数部分,如下:
start() {
[ -x $exec ] || exit 5
[ -f $config ] || exit 6
echo -n $"Starting p r o g : " d a e m o n − − p i d f i l e = prog: " daemon --pidfile= prog:"daemonpidfile={pidfile} $exec a r g s − r / s v n / p r o j e c t r e t v a l = args -r /svn/project retval= argsr/svn/projectretval=?
echo
[ $retval -eq 0 ] && touch $lockfile
return $retval
}
完成

防火墙配置
vi /etc/sysconfig/iptables

-A INPUT -m state --state NEW -m tcp -p tcp --dport 3690 -j ACCEPT

/etc/init.d/iptables restart

#start 开启
#restart 重启

Authorization failed 解决方案
例如你执行了

svnadmin create works 创建了一个works版本库,然后你运行svnserve启动服务的时候 -r参数需要制定works的上一级目录,要不然也会出现

authorization failed错误!

示例路径pwd:/alidata/svn/works

svnserve -d -r /home/svn

这样一来auth文件里的[repos:/]参数才起作用!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值