`
lifaming15
  • 浏览: 58398 次
  • 来自: ...
文章分类
社区版块
存档分类

CentOS下独立SVN服务器的安装与配置详细过程

 
阅读更多
1.下载subversion安装包之后解压,进入subversion目录
wget http://subversion.tigris.org/downloads/subversion-1.6.6.tar.gz
wget http://subversion.tigris.org/downloads/subversion-deps-1.6.6.tar.gz
tar xfvz subversion-1.6.6.tar.gz
tar xfvz subversion-deps-1.6.6.tar.gz
cd subversion-1.6.6

2.编译
首先检测系统有没有安装SSL:

find / -name opensslv.h

如果找不到,就执行如下命令进行安装:

yum install openssl
yum install openssl-devel

安装之后用find / -name opensslv.h命令找到opensslv.h所在的目录,即下列--with-openssl=后面的路径,
编译:

./configure --prefix=/usr/local/svn --with-openssl=/usr/include/openssl --without-berkeley-db

注:以svnserve方式运行,不加apache编译参数。以fsfs格式存储版本库,不编译berkeley-db。

如果编译时报如下错误:

no acceptable C compiler found in $PATH

则使用如下命令安装gcc后再编译:

yum -y install gcc

如果最后出现下面WARNING,我们直接忽略即可,因为不使用BDB存储。

configure: WARNING: we have configured without BDB filesystem support
You don't seem to have Berkeley DB version 4.0.14 or newer
installed and linked to APR-UTIL. We have created Makefiles which
will build without the Berkeley DB back-end; your repositories will
use FSFS as the default back-end. You can find the latest version of
Berkeley DB here:
http://www.sleepycat.com/download/index.shtml

3.安装
为避免出现以下错误

error while loading shared libraries: libiconv.so.2: cannot open shared object file: No such file or directory

先执行以下操作:
(1)、编辑/etc/ld.so.conf文件:

vi /etc/ld.so.conf

添加下面一行:

/usr/local/lib

(2)、保存后运行ldconfig:

/sbin/ldconfig

注:ld.so.conf和ldconfig用于维护系统动态链接库。

安装

make && make install

安装完成,执行以下命令测试:

/usr/local/svn/bin/svnserve --version

为了方便下操作,下面将SVN的BIN添加到PATH:

vi /etc/profile

倒数第二行添加:

PATH=/usr/local/svn/bin:$PATH

保存后,使其立即生效:

source /etc/profile

4.配置svn
建立版本库目录,可建多个:

mkdir -p /home/svndata/repos

建立版本库:

svnadmin create /home/svndata/repos

修改版本库配置文件:

vi /home/svndata/repos/conf/svnserve.conf

内容修改为:

[general]
anon-access = none
auth-access = write
password-db = /usr/local/svn/conf/passwd.conf
authz-db = /usr/local/svn/conf/authz.conf
realm = repos

注意:对用户配置文件的修改立即生效,不必重启svn。

在/usr/local/svn/下面新建conf文件并再/usr/local/svn/文件内新建passwd.conf和authz.conf文件:

cd /usr/local/svn/
mkdir conf
touch passwd.conf
touch authz.conf

添加用户及密码:

vi /usr/local/svn/conf/passwd.conf

添加如下代码并保存:

[users]
wll = 123456

配置svn用户访问权限:

vi /usr/local/svn/conf/authz.conf

注意:
* 权限配置文件中出现的用户名必须已在用户配置文件中定义。
* 对权限配置文件的修改立即生效,不必重启svn。
用户组格式:
[groups]
= ,
其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。
版本库目录格式:
[<版本库>:/项目/目录]
@<用户组名> = <权限>
<用户名> = <权限>
其中,方框号内部分可以有多种写法:
[/],表示根目录及以下,根目录是svnserve启动时指定的,我们指定为/home/svndata,[/]就是表示对全部版本库设置权限。
[repos:/] 表示对版本库repos设置权限;
[repos:/abc] 表示对版本库repos中的abc项目设置权限;
[repos:/abc/aaa] 表示对版本库repos中的abc项目的aaa目录设置权限;
权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。
权限可以是w、r、wr和空,空表示没有任何权限。
示例:

[groups]
admin = wll
[/]
@admin = rw
# [repos:/abc/aaa]
# king = rw
# [repos:/pass]
# king =

svn配置完毕。

建立启动svn的用户:

useradd svn
passwd svn

根据提示,为用户svn设置密码。
允许用户svn访问版本库:

chown -R svn:svn /home/svndata

启动svn:

su - svn -c "svnserve -d --listen-port 9999 -r /home/svndata"

其中:
su - svn表示以用户svn的身份启动svn;
-d表示以daemon方式(后台运行)运行;
--listen-port 9999表示使用9999端口,可以换成你需要的端口。但注意,使用1024以下的端口需要root权限;
-r /home/svndata指定根目录是/home/svndata。

5.将svn加入到开机启动
编辑rc.local文件:

vi /etc/rc.d/rc.local

加入如下启动命令:

/usr/local/svn/bin/svnserve -d --listen-port 9999 -r /home/svndata

如果想停止svn,则使用如下命令:

killall svnserve

如果想将svn作为服务:
在/etc/rc.d/init.d/目录下新建名为svn的文件并设置权限为755,并添加如下代码:

#!/bin/bash
# build this file in /etc/rc.d/init.d/svn
# chmod 755 /etc/rc.d/init.d/svn
# centos下可以用如下命令管理svn: service svn start(restart/stop)
SVN_HOME=/home/svndata
if [ ! -f "/usr/local/svn/bin/svnserve" ]
then
    echo "svnserver startup: cannot start"
    exit
fi
case "$1" in
    start)
        echo "Starting svnserve..."
        /usr/local/svn/bin/svnserve -d --listen-port 9999 -r $SVN_HOME
        echo "Finished!"
        ;;
    stop)
        echo "Stoping svnserve..."
        killall svnserve
        echo "Finished!"
        ;;
    restart)
        $0 stop
        $0 start
        ;;
    *)
        echo "Usage: svn { start | stop | restart } "
        exit 1
esac

6.连接SVN
安装TortoiseSVN,重启系统。
启动TortoiseSVN并在地址栏中输入svn://192.168.x.x:9999/repos
根据提示输入用户名与密码后就可以使用版本控制啦。

7。钩子

hooks/post-commint

#!/bin/sh
cd /home/wwwroot/iidear/
SVN=/usr/local/bin/svn
WEB=/home/wwwroot/iidear/
export LANG=en_US.UTF-8
$SVN update $WEB --username fankys --password lovelove

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics