CentOS上SVN服务器端程序的安装与使用教程

时间:2022-06-28 05:26:44

1.环境
centos6.4

2.安装svn
 

复制代码

代码如下:


yum -y install subversion


3.配置
建立版本库目录

复制代码

代码如下:


mkdir /www/svndata
svnserve -d -r /www/svndata


4.建立版本库
创建一个新的Subversion项目

复制代码

代码如下:


svnadmin create /var/www/svndata/njlrxx


配置允许用户jiqing访问

复制代码

代码如下:


cd /var/www/svndata/njlrxx/conf
vi svnserve.conf
anon-access=none
auth-access=write
password-db=passwd


注:修改的文件前面不能有空格,否则启动svn server出错

复制代码

代码如下:


vi passwd
[users]
#<用户1> = <密码1>
#<用户2> = <密码2>
jiqing=123456


5.客户端连接

复制代码

代码如下:


svn co svn://ip/njlrxx


用户名:jiqing
密码:123456

 

6.实现SVN与WEB同步,可以CO一个出来,也可以直接配在仓库中
(1)设置WEB服务器根目录为/var/www/webroot
(2)checkout一份SVN
 

复制代码

代码如下:


svn co svn://localhost/njlrxx /var/www/webroot/njlrxx


修改权限为WEB用户

复制代码

代码如下:


chown -R apache:apache /var/www/webroot/njlrxx


(3)建立同步脚本

复制代码

代码如下:


cd /var/www/svndata/njlrxx/hooks/
cp post-commit.tmpl post-commit


编辑post-commit,在文件最后添加以下内容

复制代码

代码如下:


REPOS="$1"
REV="$2"
BASEPATH=/var/www/webroot/njlrxx
WEBPATH="$BASEPATH/"
export LANG=zh_CN.UTF-8
svn update $WEBPATH --username jiqing --password 123456 --no-auth-cache


增加脚本执行权限

复制代码

代码如下:


chmod +x post-commit


最后操作是关闭服务然再打开服务:
svn服务的关闭:

复制代码

代码如下:


killall svnserve


svn开启:

复制代码

代码如下:


svnserve -d -r /var/www/svndata

 

7.如何支持匿名用户访问
方法一:
在svn安装目录下找到,conf/httpd.conf文件,如果是手动集成apache的则找到apache的配置文件。
找到中的
 

复制代码

代码如下:


Require valid-user


改为

复制代码

代码如下:


<LimitExcept GET PROPFIND OPTIONS REPORT>
Require valid-user
</LimitExcept>


重启服务,这样设置以后,svn下的所有内容都不在需要验证用户,可以直接访问。
缺点:svn自身的访问权限设置失效了。更多的时候我们希望用户先用匿名方式尝试访问,如果不行,在输入用户名和密码验证访问。

 

方法二:
在配置文件中加入
 

复制代码

代码如下:


Satisfy Any


加入了Satisfy Any的设置,其表示在同时启用了Allow(允许)和Require的情况下,指定相关策略的,一共有两个备选值,All表示用户必须同时满足Allow和Require的条件,而Any则是满足其中之一即可。
Satisfy Any表示允许先用匿名方式尝试访问,并根据svnauthz对匿名用户的控制给予访问权限。

 

PS:SVN自动同步程序执行流程:
1、用户提交文件到SVN服务器,提交操作成功后触发post-commit脚本
2、在post-commit版本文件中使用php_script.php执行PHP脚本
3、在PHP脚本中通过exec系统调用更新服务器上的版本库工作副本
4、根据更新操作结果日志,对另一个SVN版本库进行对应的操作处理