Ubuntu14下安装svn仓库,以及权限配置

    xiaoxiao2023-07-30  131

    sudo apt-get update

    接下来安装svn

    apt-get install subversionapt-get install libapache2-svn

    检查svn是否安装成功了:

    svn --version

    检查svn是否安装成功了:

    # svn --versionsvn, version 1.8.8 (r1568071)   compiled Aug 20 2015, 12:51:30 on x86_64-pc-linux-gnuCopyright (C) 2013 The Apache Software Foundation.This software consists of contributions made by many people;see the NOTICE file for more information.Subversion is open source software, see http://subversion.apache.org/The following repository access (RA) modules are available:* ra_svn : Module for accessing a repository using the svn network protocol.  - with Cyrus SASL authentication  - handles 'svn' scheme* ra_local : Module for accessing a repository on local disk.  - handles 'file' scheme* ra_serf : Module for accessing a repository via WebDAV protocol using serf.  - using serf 1.3.3  - handles 'http' scheme  - handles 'https' scheme如果出现上面的命令,说明svn安装成功了

    1.       新建一个目录用于存储SVN所有文件

    # mkdir /svn

    2.       新建一个资源仓库

    # svnadmin create /svn/project

    ls /svn/project/

    conf  db  format  hooks  locks  README.txt

    目录用途说明:

    l  hooks目录:放置hook脚本文件的目录

    l  locks目录:用来放置subversiondb锁文件和db_logs锁文件的目录,用来追踪存取文件库的客户端

    l  format文件:是一个文本文件,里面只放了一个整数,表示当前文件库配置的版本号

    l  conf目录:是这个仓库的配置文件(仓库的用户访问账号、权限等)

    3.       配置svn服务的配置文件svnserver.conf文件

    # vi /svn/project/conf/svnserve.conf

    [general]

    anon-access = none

    auth-access = write

    password-db = /svn/project/conf/passwd

    authz-db = /svn/project/conf/authz

    realm = My Test Repository         #这是个提示信息

    保存

    4.       添加两个访问用户及口令

    # vi /svn/project/conf/passwd

    #下面是3个用户,密码都是123456

    [users]

    xiaoran.shen = 123456

    test1 = 123456

    test2 = 123456

    保存

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

    5.  配置新用户的授权文件

    # vi /svn/project/conf/authz

    [groups]

    admin = xiaoran.shen,test1

    user = test2

    #[表示]svn上的东西都可以看到。

    [/]

    @admin = rw     #表示admin这个组里面的人都可以读和写操作

    @user = r           #表示user这个组下的人只可以看

    * =         

    保存

    格式说明:

    版本库目录格式: 

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

    @<用户组名> = <权限

    <用户名> = <权限>

    表示对根目录(即/svn/project目录)下的所有子目录范围设置权限;

    [/abc] 表示对资料库中abc项目设置权限;

    创建一个admin组,组成员包括xiaoran.shentest1

    创建一个user组,成员只有test2

    admin组对目录有读写权限;

    单个用户test2有读写权限;

    *=表示除了上面设置的权限用户组以外,其他所有用户都设置空权限,空权限表示禁止访问本目录,这很重要一定要加上。

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

    如果想配置[/]下有两个人可以看,[/doc]文件夹先的内容只有两个人可以看到可以配置成类似:

    [groups]admin = test1,test2user = test3,test4[/]@admin = rw* =[/docdetection]@admin = rw@user = rw* =

    经过上面的配置之后user里面的人只可以看“svn://你的服务器ip/docdetection中的内容,而admin组里面的人可以看到“svn://你的服务器ip/”中的所有内容

    6. 启动svn服务

    svnserve -d -r /svn/project/

    注意:不要使用系统提供的 /etc/init.d/svnserve start 来启动,因为系统默认的启动脚本中没有使用 –r /svn/project参数指定一个资源。这种情况下启动的svn服务,客户端连接会提示“svn: No repository found in 'svn://192.168.11.229/' ”这样的错误。

    默认svn服务器端口是3690。     (注意:访问的时候不用加上端口号)

    杀死svn服务:

    # ps -ef|grep svn

    root      4642     1  0 16:08 ?        00:00:00 svnserve -d -r /svn/project/

    root      4692  3676  0 16:13 pts/2    00:00:00 grep svn

    # kill -9 4642

    若要使用/etc/init.d/svnserve 脚本,可以修改start()函数部分,如下:

    start() {

        [ -x $exec ] || exit 5

        [ -f $config ] || exit 6

        echo -n $"Starting $prog: "

        daemon --pidfile=${pidfile} $exec $args -r /svn/project

        retval=$?

        echo

        [ $retval -eq 0 ] && touch $lockfile

        return $retval

    }

    完成

    最新回复(0)