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版本库进行对应的操作处理