sudo apt-get update
接下来安装svn
apt-get install subversion
apt-get install libapache2-svn
检查svn是否安装成功了:
svn --version
检查svn是否安装成功了:
# svn --version
svn,version 1.8.8 (r1568071)
compiled Aug 20 2015,12:51:30 on x86_64-pc-linux-gnu
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 access (RA) modules are available:
* ra_svn : Module for accessing a repository using the svn network protocol.
- with Cyrus SASL authentication
- handles 'svn' scheme
* ra_local : Module for accessing a repository on local disk.
- handles 'file' scheme
* ra_serf : Module for accessing a repository via WebDAV protocol using serf.
- using serf 1.3.3
- handles 'http' scheme
- handles 'https' scheme
如果出现上面的命令,说明svn安装成功了
1.新建一个目录用于存储SVN所有文件
# mkdir /svn
2.新建一个资源仓库
@H_502_82@# svnadmin create /svn/project ls /svn/project/confdbformathookslocksREADME.txt
@H_502_82@目录用途说明:lhooks目录:放置hook脚本文件的目录
llocks目录:用来放置subversion的db锁文件和db_logs锁文件的目录,用来追踪存取文件库的客户端
lformat文件:是一个文本文件,里面只放了一个整数,表示当前文件库配置的版本号
lconf目录:是这个仓库的配置文件(仓库的用户访问账号、权限等)
3.配置svn服务的配置文件svnserver.conf文件
@H_502_82@# vi /svn/project/conf/svnserve.conf @H_502_82@[general] @H_502_82@anon-access = none @H_502_82@auth-access = write @H_502_82@password-db = /svn/project/conf/passwd @H_502_82@authz-db = /svn/project/conf/authz @H_502_82@realm = My Test Repository#这是个提示信息 @H_502_82@保存 @H_502_82@# vi /svn/project/conf/passwd @H_502_82@#下面是3个用户,密码都是123456 @H_502_82@[users] @H_502_82@xiaoran.shen = 123456 @H_502_82@test1 = 123456 @H_502_82@test2 = 123456@H_502_82@注意:对用户配置文件的修改立即生效,不必重启svn服务。 @H_502_82@# vi /svn/project/conf/authz @H_502_82@[groups] @H_502_82@admin = xiaoran.shen,test1 @H_502_82@user = test2 @H_502_82@
@H_502_82@#[表示]svn上的东西都可以看到。 @H_502_82@[/] @H_502_82@@admin= rw #表示admin这个组里面的人都可以读和写操作 @H_502_82@@user= r #表示user这个组下的人只可以看 @H_502_82@* = @H_502_82@格式说明: @H_502_82@版本库目录格式: @H_502_82@[<版本库>:/项目/目录] @H_502_82@@<用户组名>=<权限> @H_502_82@<用户名>=<权限> @H_502_82@/表示对根目录(即/svn/project目录)下的所有子目录范围设置权限; @H_502_82@[/abc]表示对资料库中abc项目设置权限; @H_502_82@创建一个admin组,组成员包括xiaoran.shen和test1 @H_502_82@创建一个user组,成员只有test2; @H_502_82@admin组对目录有读写权限; @H_502_82@单个用户test2有读写权限; @H_502_82@*=表示除了上面设置的权限用户组以外,其他所有用户都设置空权限,空权限表示禁止访问本目录,这很重要一定要加上。 @H_502_82@注意:对权限配置文件的修改立即生效,不必重启svn。 @H_502_82@如果想配置[/]下有两个人可以看,[/doc]文件夹先的内容只有两个人可以看到可以配置成类似: @H_502_82@[groups]
admin = test1,test2
user = test3,test4
[/]
@admin = rw
* =
[/docdetection]
@admin = rw
@user = rw
* =
@H_502_82@经过上面的配置之后user里面的人只可以看“svn://你的服务器ip/docdetection”中的内容,而admin组里面的人可以看到“svn://你的服务器ip/”中的所有内容 @H_502_82@
6.启动svn服务
svnserve -d -r /svn/project/
@H_502_82@注意:不要使用系统提供的/etc/init.d/svnserve start来启动,因为系统默认的启动脚本中没有使用–r /svn/project参数指定一个资源。这种情况下启动的svn服务,客户端连接会提示“svn: No repository found in 'svn://192.168.11.229/'”这样的错误。 @H_502_82@默认svn服务器端口是3690。 (注意:访问的时候不用加上端口号) @H_502_82@杀死svn服务: @H_502_82@# ps -ef|grep svn @H_502_82@root464210 16:08 ?00:00:00 svnserve -d -r /svn/project/ @H_502_82@root469236760 16:13 pts/200:00:00 grep svn @H_502_82@# kill -9 4642 @H_502_82@ @H_502_82@若要使用/etc/init.d/svnserve脚本,可以修改start()函数部分,如下: @H_502_82@start() { @H_502_82@[ -x $exec ] || exit 5 @H_502_82@[ -f $config ] || exit 6 @H_502_82@echo -n $"Starting $prog: " @H_502_82@daemon --pidfile=${pidfile} $exec $args-r /svn/project @H_502_82@retval=$? @H_502_82@echo @H_502_82@[ $retval -eq 0 ] && touch $lockfile @H_502_82@return $retval @H_502_82@} 完成