如何配置自己的Linux svnserver服务器

发布网友 发布时间:2022-04-19 14:30

我来回答

1个回答

热心网友 时间:2023-01-22 04:13

一、新建并初始化版本库   1.新建代码仓库   # svnadmin create /home/myrepos   这样,我们就在/home目录下新建了版本库myrepos。   2.初始化代码仓库   #mkdir -p code/{branches,tags,trunk}   按照svn手册上的建议,我们版本库的布局采用branches/tags/trunk这样的三个目录。然后可以将代码直接拷贝的trunk目录,也可以随后采用svn add的方式添加。      #svn import code file: ///home/myrepos   将我们构造好的版本库布局(以及代码,如果已经拷贝到trunk下的话)提交到版本库。由于这里我们是在本地操作,因此可以直接使用file协议方式提交。格式为:file:// + 版本库绝对的路径      OK,到这里我们已经构建了一个本地版本库,可以再本地使用svn ci的方法得到版本库的副本了。如果前面只是提交了版本库布局,而没有提交代码的话,则可以通过如下命令,提交版本代码:   #svn co file: ///home/myrepos/trunk repos   通常只从主线目录trunk下取出源码,放在了新建的repos目录。然后可以将源码拷贝到repos目录。   执行以下两条命令将代码添加的版本库。   #svn add *   #svn ci * -m "Committed codes"   首先需要将拷贝的代码加入到当前的副本中,然后将代码提交到版本库。      二、配置并启动svnserve   1. 配置svnserve   这一步主要完成远程用户访问版本的权限。   在版本库目录下有个conf目录:home/myrepos/conf,该目录包含三个文件:authz,passwd,svnserve.conf。   (1)svnserve.conf      此文件重点的设置内容如下:   anon-access = read   auth-access = write   password-db = passwd   authz-db = authz   其中,anon-acces s和auth-access分别代表设置匿名用户和授权用户的访问权限。read代表只读,write代表可读可写,还有一个none,代表禁止访问。如果不想让匿名用户访问的话,可以设置anon-access = none。   password-db为保存版本库的用户名和密码,通常为conf目录下的passwd文件。   authz-db指向的文件,主要用于将用户进行分组,并赋予不同的组不同的权限。譬如有多个目录时,设置某个组的用户只可以访问其中的那些目录。   (2)passwd   如前面介绍,这个文件的主要内容如下   [users]   harry = harrysecret   sally = sallyssecret   以上两行就是可以访问版本库的用户名和密码。格式为:user = passwd。   (3)authz   [groups]   # harry_and_sally = harry,sally      # [/foo/bar]   # harry = rw   # * =      # [repository:/baz/fuz]   # @harry_and_sally = rw   # * = r   以上就是authz文件的格式。先给用户分组,然后分别设置每个组的工作目录以及权限等。   本文的讲解并未用到authz的配置。   

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com