zoukankan      html  css  js  c++  java
  • linux下安装配置svn服务器

    linux下安装配置svn服务器

    1. svn服务器安装

    将subversion-1.4.0.tar.gz和subversion-deps-1.4.0.tar.gz传到服务器。

    tar xfvz subversion-1.4.0.tar.gz

    tar xfvz subversion-deps-1.4.0.tar.gz

    cd subversion-1.4.0

    ./configure –prefix=/opt/svn –without-berkeley-db –with-zlib

    或者

    [root@server subversion-1.6.6]# find / -name opensslv.h

    /usr/include/openssl/opensslv.h

    [root@server subversion-1.6.6]# ./configure --prefix=/usr/local/svn --with-openssl=/usr/include/openssl --without-berkeley-db

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

    make clean

    make

    make install

    vi /etc/profile,在/etc/profile最后加入:

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

    svn测试

    svnserve -version

    如果显示如下,svn安装成功:

    svnserve, version 1.4.0 (r21228)

    compiled Oct 12 2006, 10:18:56Copyright (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_fs : Module for working with a plain file (FSFS) repository.

    2. svn配置

    [root@server ~]# mkdir -p /home/svndata/dsm       #建立版本库

    [root@server ~]# /usr/local/svn/bin/svnadmin create /home/svndata/ dsm

    修改svn版本库配置文件

    版本库1:

    vi / home /svndata/dsm/conf/svnserve.conf

    内容修改为:

    [general]

    anon-access = none

    auth-access = write

    password-db = /opt/svn/conf/pwd.conf

    authz-db = /opt/svn/conf/authz.conf

    realm = dsm

    即除realm = repos2外,其他与版本库1配置文件完全相同。如果有更多的版本库,依此类推。

    配置允许访问的svn用户

    vi /usr/local/svn/conf/pwd.conf

    为了简化配置,2个版本库共用1个用户配置文件。如有必要,也可以分开。

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

    文件格式如下:

    [users]

    <用户1> = <密码1>

    <用户2> = <密码2>

    其中,[users]是必须的。下面列出要访问svn的用户,每个用户一行。示例:

    [users]

    alan = password

    king = hello

    配置svn用户访问权限

    vi /opt/svn/conf/authz.conf

    为了简化配置,3个版本库共用1个权限配置文件/opt/svn/conf/pwd.conf。如有必要,也可以分开。文件中定义用户组和版本库目录权限。

    注意:

    * 权限配置文件中出现的用户名必须已在用户配置文件中定义。

    * 对权限配置文件的修改立即生效,不必重启svn。

    用户组格式:

    [groups]

    <用户组名> = <用户1>,<用户2>

    其中,1个用户组可以包含1个或多个用户,用户间以逗号分隔。

    版本库目录格式:

    [<版本库>:/项目/目录]

    @<用户组名> = <权限>

    <用户名> = <权限>

    其中,方框号内部分可以有多种写法:

    /,表示根目录及以下。根目录是svnserve启动时指定的,我们指定为/opt/svndata。这样,/就是表示对全部版本库设置权限。

    dsm:/,表示对版本库1设置权限

    repos2:/abc, ,表示对版本库2中的abc项目设置权限

    repos2:/abc/aaa, ,表示对版本库2中的abc项目的aaa目录设置权限

    权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。权限可以是w、r、wr和空,空表示没有任何权限。

    示例:

    [groups]

    admin = alan

    [/]

    @admin = rw

    [dsm:/abc/aaa]

    king = rw

    [repos2:/pass]

    king =

    [/]

    dongzhukai = rw

    [/root]

    @document_user = r

    [/root/document]

    @document_user = rw

    [/root/code]

    dongzhukai = rw

    @document_user = rw

    svn配置完毕,删除无用文件

    rm /opt/svndata/dsm/conf/authz

    rm /opt/svndata/dsm/conf/passwd

    rm /opt/svndata/repos2/conf/authz

    rm /opt/svndata/repos2/conf/passwd

    3. 启动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 /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

    4、SVN客户端访问地址:

    svn://192.168.1.87:9999/repos

  • 相关阅读:
    Python 生成器相关知识
    openpyxl 模块学习记录
    Python 装饰器相关知识
    Python 闭包的相关知识
    Python 内置函数简单介绍
    Git提交的本地仓库在什么位置
    支付宝公钥,私钥加密解密问题
    字符转义
    pyhton 模拟浏览器实现
    大小端模式 大端存储 小端存储
  • 原文地址:https://www.cnblogs.com/alliswell2king/p/11757431.html
Copyright © 2011-2022 走看看