CentOS7.2 SVN服务端安装配置

1、安装svn服务器

Yum   install subversion  -y

安装完毕后可以用 下边的命令查看是否安装完成,如果现实出版本号和版权信息等等就证明安装完成。

svn --version

svn --version 成功后展示如下信息

svn, version 1.8.8 (r1568071)

   compiled Aug 20 2015, 12:51:30 on x86_64-pc-linux-gnu

 

Copyright (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

 

 

2、创建版本库

  首先创建目录,根据你的需要创建svn目录。我目录是:/usr/svn/test

  然后创建版本仓库:

svnadmin create /usr/svn/test

 

3、配置svn服务器

  创建版本仓库后再 test/conf文件夹下生成了四个配置文件:authz  hooks-env.tmpl  passwd  svnserve.conf
、首先 svnserve.conf里边配置了版本库的权限,需要把下边5行的注释打开,一定注意,去掉#号的同时把空格去掉,否则svn服务不能正常运行

anon-access = none   

#控制非鉴权用户访问版本库的权限。取值范围为"write""read""none"。即"write"为可读可写,"read"为只读,"none"表示无访问权限。缺省值:read

auth-access = write

#控制鉴权用户访问版本库的权限。取值范围为"write""read""none"。即"write"为可读可写,"read"为只读,"none"表示无访问权限。缺省值:write

password-db = passwd

#指定账户密码配置文件,当前文件夹下的passwd文件

authz-db = authz

#权限配置文件,当前文件夹下的authz文件

realm = first    
#版本库的认证域,即在登录时提示的认证域名称。若两个版本库的 认证域相同,建议使用相同的用户名口令数据文件。缺省值:一个UUID(Universal Unique IDentifier,全局唯一标示)  

、配置passwd

    如下代码,配置了用户名为test的用户,并为其创建了密码test123.如需要配置多用户就多写几个吧,记得换行

### This file is an example password file for svnserve.

### Its format is similar to that of svnserve.conf. As shown in the

### example below it contains one section labelled [users].

### The name and password for each user follow, one account per line.

 

[users]

# harry = harryssecret

# sally = sallyssecrettest=test123

配置authz权限

  下边的代码为test用户创建了读和写的权限。

[groups]

# harry_and_sally = harry,sally

# harry_sally_and_joe = harry,sally,&joe

 

# [/foo/bar]

# harry = rw

# &joe = r

# * =

 

# [repository:/baz/fuz]

# @harry_and_sally = rw

# * = r

[/]test=rw

  如果用户较多,需要分角色划分权限参考下边代码

    这段代码,为test创建了admin的角色,为ttt用户创建了user的角色,最后使用@符号为角色创建权限,admin角色读写权限,user角色读权限。

[groups]

# harry_and_sally = harry,sally

# harry_sally_and_joe = harry,sally,&joe

 

# [/foo/bar]

# harry = rw

# &joe = r

# * =admin=test
user=ttt

# [repository:/baz/fuz]

# @harry_and_sally = rw

# * = r

[/]@admin=rw
@user=r

 

ok,配置已经完成,让我们启动svn服务器试试吧

  执行命令:

svnserve -d -r /usr/svn

启动服务器,-d表示守护线程后台运行,-r表示指定目录。注意:不要写成svnserve -d -r /usr/svn/test。否则虽然服务可正常启动,但是客户端用的时候可能会产生问题

 

查看是否启动成功:

ps -ef | grep svnserve

如果结果为两个线程在运行,一般是成功了。

 

4、客户端访问

  下载客户端不在赘述。

svn地址:svn://ip/test  然后输入用户名test和密码test123确认。

  是不是连上了呢?如果没有检查是否清除了旧的数据信息,

  清除旧数据方法:右键->tortoisesvn->setting->Saved Data,clear掉吧。

 

最后补充关闭svn服务器的方法:使用ps -ef | grep svnserve查看进程后,记住pid,然后  kill -9 pid  就可以关闭了。

分割线
感谢打赏
江西数库信息技术有限公司
YWSOS.COM 平台代运维解决方案
 评论
 发表评论
姓   名:

Powered by AKCMS