Linux下SVN搭建及Apache+SVN搭建
应领导的要求,开发一个源码托管平台,当然还是lamp架构,对于源码的管理,我选择了SVN服务。刚开始我将apache与svn分别安装,但如此便不利于我对svn仓库的管理,如创建仓库、添加用户等,更重要的是svn面向整个互联网,需要走http协议,这不符合网站的要求,推到重来,配置apache+svn。
1、svn独立配置
使用软件:subversion-1.6.5.tar.gz 和 subversion-deps-1.6.5.tar.gz
文件下载在安科网的1号FTP服务器里,下载地址:
密码:www.muu.cc
下载方法见这里 http://www.linuxidc.net/thread-1187-1-1.html
编译: tar -xzf subversion-1.6.5.tar.gz
tar -xzf subversion-deps-1.6.5.tar.gz
subversion-deps包有四个目录zlib apr apr-util neon这四个目录都是依赖包,编译subversion所必须的代码
#cd subversion-1.6.5
#./configure --prefix=/usr/local/svn --without-berkeley-db --with-zlib=/usr
#make
#make install
测试:#/usr/local/svn/bin/svnserve –version
如果显示如下,安装成功:
svnserve, version 1.6.5 (r21228)
配置:建立版本库目录,可建多个:
#./mkdir -p /svndata/
建立版本库:
#cd /usr/local/svn/bin
#./svnadmin create /svndata/test
修改版本库配置文件:
#vi /svndata/test/conf/svnserve.conf
[general]
anon-access = none
auth-access = write
password-db = /svndata/test/conf/pwd.conf
authz-db = /svndata/test/conf/authz.conf
realm = repos
配置允许访问的用户:
#vi /svndata/test/conf/pwd.conf
注意:对用户配置文件的修改立即生效,不必重启svn。
文件格式如下:
[users]
<用户1> = <密码1>
<用户2> = <密码2>
其中,[users]是必须的。下面列出要访问svn的用户,每个用户一行。示例:
[users]
xinjie = 123456
文件中定义用户组和版本库目录权限。
注意:
* 权限配置文件中出现的用户名必须已在用户配置文件中定义。
* 对权限配置文件的修改立即生效,不必重启svn。
用户组格式:
[groups]
<用户组名> = <用户1>,<用户2>
其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。
版本库目录格式:
[<版本库>:/项目/目录]
@<用户组名> = <权限>
<用户名> = <权限>
其中,方框号内部分可以有多种写法:
/,表示根目录及以下。根目录是svnserve启动时指定的,我们指定为/svndata。这样,/就是表示对全部版本库设置权限。
test1:/,表示对版本库1设置权限
test2:/abc, ,表示对版本库2中的abc项目设置权限
test2:/abc/aaa, ,表示对版本库2中的abc项目的aaa目录设置权限
权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。权限可以是w、r、wr和空,空表示没有任何权限。
示例:
[groups]
admin = alan
[/]
@admin = rw
[test1:/abc/aaa]
king = rw
[test2:/pass]
*=r
king = rw
启动:svnserve -d –listen-port 9999 -r /svndata
-d表示以daemon方式(后台运行)运行
–listen-port 9999表示使用9999端口,可以换成你需要的端口。
-r /svndata指定根目录是/svndata
相关推荐
pub_svnserve.conf的 pub_authz.conf的配置文件有非法字符的原因引起,需要查找pub_authz.conf提的非法内容比如多余的空格删除或直接将pub_authz.conf