Centos6.3搭建SVN服务器

来源:互联网 发布:阿里健康云药师兼职 编辑:程序博客网 时间:2024/05/02 02:59

一、简介

       SVN作为新一代代码版本管理工具,有很多优点,管理方便,逻辑明确,安全性高,代码一致性高。SVN数据存储有两种方式,BDB(事务安全表类型)和FSFS(一种不需要数据库的存储系统),为了避免在服务器连接中断时锁住数据,FSFS是一种更安全也是更多人使用的方式。SVN的运行方式也有两种,一种是独立服务器,另一种是借助apache服务,即svn://或http://。

       目前绝大多数开源软件都使用svn作为代码版本管理软件。Subversion支持linux和windows,但较多安装在linux下。

二、详解

1、svn的基本工作原理

        svn的基本工作原理: 在一台服务器上建立一个源代码库,库里可以存放许多不同项目的源程序。有源代码库管理员统一管理这些源程序。每个用户在使用源代码库之前,首先要把源代码库里的项目文件下载到本地,然后开发人员可以在本地修改,修改完成后用svn命令进行提交,由源代码库统一管理修改。
       版本控制解决了:(1)代码管理混乱(2)解决代码冲突困难(3)在代码整合期间引发bug(4)无法对代码的拥有者进行权限控制(5)项目不同版本的发布困难。

          SVN工作原理示意图:

          subversion目录说明:

(1)dav目录:是提供apache与mod_dav_svn使用的目录,让他们存储内部数据
(2)db目录:就是所有版本控制的数据存放文件
(3)hooks目录:放置hook脚本文件的目录
(4)locks目录:用来放置subversion见艰苦锁定数据的目录,用来追踪存取文件库的客户端
(5)format文件:是一个文本文件,里面只放了一个整数。表示当前文件库配置的版本号
(6)conf目录:是这个仓库的配置文件(仓库的用户访问账号、权限等)

2、svn的安装

#yum install subversion
判断是否安装成功
#svnserve --version

3、svn的配置

(1)建立svn版本库

#mkdir -p/svn/project/repos     //创建版本库所在文件夹

#svnadmin create --fs-typefsfs/svn/project/repos  //创建版本库,如果需要使用bdb方式存储,则将fsfs改成bdb即可

执行上面的命令后,自动在repos下建立多个文件, 分别是conf、 db、format、hooks、locks、README.txt

        其中文件夹conf下有authz, passwd, svnserve.conf配置文件,authz 是权限控制,   passwd是设置用户和密码的,    svnserve是设置svn相关的操作。

(2)配置passwd

#vim /svn/project/repos/conf/passwd

[users]# harry = harryssecret# sally = sallyssecrethello=123
用户名=密码,建立了hello用户, 密码123

(3)配置权限authz

#vim /svn/project/repos/conf/authz

[/]hello=rw
hello用户对所有的目录有读写权限,可以限定。

(4)配置svnserve.conf

#vim /svn/project/repos/conf/svnserve.conf

[general]anon-access = none           # 使非授权用户无法访问auth-access = write          # 使授权用户有写权限password-db = <span style="font-size:14px;">/svn/project/repos/conf/passwd</span>authz-db = <span style="font-size:14px;"><span style="font-size:14px;">/svn/project/repos/conf/<span style="font-size:14px;">authz</span></span></span>   # 访问控制文件
必须在general目录下,采用默认配置. 以上语句都必须顶格写, 左侧不能留空格, 否则会出错.

总:通过以上配置,svn就可以使用。

4、svn的启动使用

(1)启动svn服务:

#svnserve --/svn

如果已经有svn在运行,可以换一个端口运行,这样同一台服务器可以运行多个svnserver。
#svnserve --/svn--listen-port 3391
(2)初始化版本库目录

#svnimport /var/www/html file:///svn/project/repos --message "one"    //将 /var/www/html/下的文件

也可采用创建临时目录
# mkdir project project/server project/client project/test (建立临时目录)
# svn import project/ file:///svn/project -m "initialization"
# rm -rf project (删除临时建立的目录)

导入版本库

#svn list --verbose file:///svn/project/repos             //查看导入的文件

#svn info  file:///svn/project/repos              //查看svn信息


(3)重启svn
注意:如果修改了svn配置,需要重启svn服务,步骤如下:
# ps -aux|grep svnserve
# kill -9 ID号
# svnserve -d -r /svn

5、客户端连接

(1)连接svn服务器

   在局域网主机安装TortoiseSVN 连接地址为: svn://192.168.40.125/project/repos (如果指定端口需要添加端口号:端口号)。

#svn co svn://192.168.40.125/project/repos

输入上面设置的用户名和密码:


(2)上传提交文件

#cd repos

#vim main.c

#svn add main.c

#svn commit main.c -m "upload file"

(3)客户端查看信息

6、配置SVN服务器的HTTP支持

svn作为独立服务器或借助apache服务的两种方式,可同时使用。

(1)转换SVN服务器的密码

   因为svn密码为明文,http不支持明文.需要生成一个webpasswd文件,首次创建new的webpass文件用-c。

#cd /svn/project/repos/conf

#htpasswd -c webpasswd hello

目录下会多一个webpasswd文件

注意如果需要,多次加入用户,则用htpasswd -m
#htpasswd -m webpasswd hello2

(2)配置apache

#vim /etc/httpd/conf/httpd.conf

在最后添加如下信息:

<Location /svn>DAV svnSVNPath /svn/project/repos/AuthType BasicAuthName "svn for project"AuthUserFile /svn/project/repos/conf/webpasswdAuthzSVNAccessFile /svn/project/repos/conf/authzSatisfy allRequire valid-user</Location>
(3)重启httpd

#/etc/init.d/httpd restart
出现Unknown DAV provider: svn的错误,是因为系统没有安装mod_dav_svn它是Subversion与Apache之间的接口(通过它,Apache就可以访问版本库,可以让客户端也使用HTTP的扩展协议 WebDAV/DeltaV进行访问)

#yum install mod_dav_svn    //使subversion与dav模块通信的功能

#yuminstallmod_authz_svn  //实现权限控制功能

再重启即可。

(4)使用浏览器访问http://192.168.40.125/svn/

若单独设置端口号,网址为http://IP地址:端口/svn。

出现<m:human-readable errcode="13">的错误,请检查cat /etc/sysconfig/selinux设置SELINUX=disabled,需重启系统,或使用setenforce 0临时禁止。


总:现在就可以通过svn co svn://192.168.40.125/project/repos和http://192.168.40.125/svn/两种方式访问svn服务器了。

四、总结

(1)svn设置权限的时候passwd和webpasswd不能弄反,否则用户无法登录。

(2)暂时没有涉及到多用户和用户权限分别设置的内容,以后使用时可自行设置。

(3)svn还有与邮箱同步、与数据库同步等内容。

(4)本人思路有限,若有更好的设计建议,也可发邮件沟通,在此先感谢!邮箱地址aoyang888@qq.com。

0 0
原创粉丝点击