SVN服务器的配置和web目录的整合

December 25th, 2009 by admin Leave a reply »

下载软件:

http://subversion.tigris.org/downloads/subversion-1.6.2.tar.gz

http://subversion.tigris.org/downloads/subversion-deps-1.6.2.tar.gz

http://www.zlib.net/zlib-1.2.3.tar.gz

tar zxvf zlib-1.2.3.tar.gz
cd zlib-1.2.3
./configure -prefix=/usr/local/zlib
make
make install
tar zxvf subversion-1.6.2.tar.gz
cd subversion-1.6.2
./configure -prefix=/home/svn -without-berkeley-db -with-zlib=/usr/local/zlib
make clean
make
make install
vi /etc/profile
增加如下:
PATH=$PATH:/opt/svn/bin
export PATH
svnadmin -version 查看版本号
svnadmin –version
svnadmin, version 1.4.2 (r22196)
compiled Nov 20 2006, 07:17:37

Copyright (C) 2000-2006 CollabNet.
Subversion is open source software, see http://subversion.tigris.org/
This product includes software developed by CollabNet (http://www.Collab.Net/).

The following repository back-end (FS) modules are available:

* fs_base : Module for working with a Berkeley DB repository.
* fs_fs : Module for working with a plain file (FSFS) repository.

创建版本库目录
mkdir -p /home/svndata/36

建立版本库
svnadmin create /home/svndata/36

vi /home/svndata/36/conf/svnserve.conf
内容修改为:
[general]
anon-access = none
auth-access = write
password-db = passwd
authz-db = autzhz
realm = 36
注意:对用户配置文件的修改立即生效,不必重启svn

Passwd和auzhz文件示例如下:
文件格式如下:
[users]
<用户1> = <密码1>
<用户2> = <密码2>
其中,[users]是必须的。下面列出要访问svn的用户,每个用户一行。示例:
[users]
alan = password
king = hello
配置svn用户访问权限vi /opt/svn/conf/authz.conf

注意:
* 权限配置文件中出现的用户名必须已在用户配置文件中定义。
* 对权限配置文件的修改立即生效,不必重启svn。
用户组格式:
[groups]
<用户组名> = <用户1>,<用户2>
其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。
版本库目录格式:
[<版本库>:/项目/目录]
@<用户组名> = <权限>
<用户名> = <权限>
其中,方框号内部分可以有多种写法:
/,表示根目录及以下。根目录是svnserve启动时指定的,我们指定为/opt/svndata。这样,/就是表示对全部版本库设置权限。
repos1:/,表示对版本库1设置权限
repos2:/abc, ,表示对版本库2中的abc项目设置权限
repos2:/abc/aaa, ,表示对版本库2中的abc项目的aaa目录设置权限
权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。权限可以是w、r、wr和空,空表示没有任何权限。
示例:
[groups]
admin = alan
[/]
@admin = rw
[repos1:/abc/aaa]
king = rw
[repos2:/pass]
king =
创建svn用户
useradd svn
passwd svn
chown -R svn.svn /home/svndata/36
启动svn:
su – svn -c “svnserve -d -listen-port 8899 -r /home/svndata”
其中:
su – svn表示以用户svn的身份启动svn
-d表示以daemon方式(后台运行)运行
-listen-port 9999表示使用9999端口,可以换成你需要的端口。但注意,使用1024以下的端口需要root权限
-r /opt/svndata指定根目录是/opt/svndata

检查:
ps -ef|grep svnserve
如果显示如下,即为启动成功:
svn    6941   1 0 15:07 ?    00:00:00 svnserve -d -listen-port 9999 -r /opt/svndata

接下来安装TortoiseSVN-1.5.5.14361-win32-svn-1.5.4.msi客户端进行checkout就可以啦。
svn服务器与web目录的整合。
实现这个需要用到svn的钩子,文件也就是版本库里面的hooks目录下面的post-commit文件。
在我工作的时候,实现的功能所配置的这个文件内容为:
vi post-commit

#!/bin/sh
export LANG=en_US.UTF-8

/usr/bin/svn checkout svn://localhost:8899/ /home/htdocs/wwww –username zhouct –password zhouct

实现这个的前提是,你的svn启动用户要和你的web目录要一致,否则可能出现权限的问题。
我是以www用户,也就是web启动的用户来启动svn进程的。
su – www -c “svnserve -d –listen-port 8899 -r /home/svndata/php”
此命令为,以www用户启动svn进程,监听端口为:8899,版本库为:/home/svndata/php/

进程启动之后 ,然后在本地以svn客户端,修改或者创建新的版本文件,当commit的时候,就会自动update至/home/htdocs/wwww 这个web目录下面
提交之后即可实现以浏览器查看效果。

这是第一次实现,svn版本与web目录整合的工作,中间遇到了很多权限的问题,就可能是svn启动的用户,和web目录用户不一致造 成的。把它设置成同一个用户即可实现。

Advertisement

1 comment

Leave a Reply