码迷,mamicode.com
首页 > Web开发 > 详细

svn+apache配置多版本库

时间:2015-06-16 19:35:23      阅读:804      评论:0      收藏:0      [点我收藏+]

标签:svn+apache配置多版本库

一、环境

系统:    CentOS 6.4x64最小化安装

IP:      192.168.3.67

二、安装

配置epel源

[root@svn ~]# rpm  -ivh http://mirrors.sohu.com/fedora-epel/6/x86_64/epel-release-6-8.noarch.rpm
Retrieving http://mirrors.sohu.com/fedora-epel/6/x86_64/epel-release-6-8.noarch.rpm
warning: /var/tmp/rpm-tmp.fOwTB2: Header V3 RSA/SHA256 Signature, key ID 0608b895: NOKEY
Preparing...                ########################################### [100%]
   1:epel-release           ########################################### [100%]
[root@svn ~]# sed -i ‘s@#baseurl@baseurl@‘ /etc/yum.repos.d/epel.repo
[root@svn ~]# sed -i ‘s@mirrorlist@#mirrorlist@‘ /etc/yum.repos.d/epel.repo

同步时间

[root@svn ~]# yum install ntp -y
[root@svn ~]# ntpdate asia.pool.ntp.org
16 Jun 10:34:12 ntpdate[1467]: step time server 202.73.36.32 offset 174.669497 sec
[root@svn ~]# hwclock -w
[root@svn ~]# echo "*/10 * * * * /usr/sbin/ntpdate asia.pool.ntp.org &>/dev/null" >>/var/spool/cron/root

安装相关软件包

[root@svn ~]# yum install httpd httpd-devel mod_dav_svn subversion mod_ssl -y

#查看安装后的结果
[root@svn ~]# ls /etc/httpd/modules/ |grep svn
mod_authz_svn.so
mod_dav_svn.so
[root@svn ~]# svn --version |grep version
svn, version 1.6.11 (r934486)
Subversion is open source software, see http://subversion.tigris.org/

三、配置svn服务器

创建一个用来存放svn代码库的目录

[root@svn ~]# mkdir -p /data/svn

#新建一个版本库
[root@svn ~]# cd /data/svn/
[root@svn svn]# mkdir test
[root@svn svn]# svnadmin create /data/svn/test/
[root@svn svn]# ll test/
total 24
drwxr-xr-x 2 root root 4096 Jun 16 10:46 conf
drwxr-sr-x 6 root root 4096 Jun 16 10:46 db
-r--r--r-- 1 root root    2 Jun 16 10:46 format
drwxr-xr-x 2 root root 4096 Jun 16 10:46 hooks
drwxr-xr-x 2 root root 4096 Jun 16 10:46 locks
-rw-r--r-- 1 root root  229 Jun 16 10:46 README.txt
[root@svn svn]# chown -R apache.apache /data/svn/

配置subversion.conf

[root@svn svn]# egrep -v "^$|^#" /etc/httpd/conf.d/subversion.conf 
LoadModule dav_svn_module     modules/mod_dav_svn.so
LoadModule authz_svn_module   modules/mod_authz_svn.so
<Location /repos>
   DAV svn
   SVNParentPath /data/svn     #(SVNParentPath:支持多个具备相同父目录的Subversion版本库。) 
      AuthType Basic
      AuthName "Authorization Realm"
      AuthUserFile /data/svn/passwd            #配置用户对svn版本库的用户密码文件
      AuthzSVNaccessFile /data/svn/authz       #用户访问svn版本库的权限控制文件
      Require valid-user
</Location>

配置版本库test的配置文件

[root@svn svn]# egrep -v "^#|^$" /data/svn/test/conf/svnserve.conf 
[general]
anon-access = read
auth-access = write
password-db = /data/svn/passwd                #用户密码信息
authz-db = /data/svn/authz                    #用户权限认证文件
[sasl]

#创建用户密码文件
[root@svn svn]# htpasswd -c /data/svn/passwd lyao        #第一次使用-c选项
New password:                    
Re-type new password:         #密码lyao36843
Adding password for user lyao
[root@svn svn]# htpasswd /data/svn/passwd weyee
New password: 
Re-type new password:         #密码weyee2014
Adding password for user weyee
[root@svn svn]# cat /data/svn/passwd 
lyao:hV1uxQp0s2AkI
weyee:VSAZ2tGIccUsA

#配置权限认证文件
[root@svn svn]# egrep -v "^#|^$" /data/svn/authz 
[aliases]
[groups]
admin = weyee
yunwei = lyao
[test:/]
@admin = rw
@yunwei = r

启动httpd服务

[root@svn ~]# echo "ServerName localhost:80" >>/etc/httpd/conf/httpd.conf 
[root@svn ~]# service httpd start
Starting httpd:                                            [  OK  ]
[root@svn ~]# service iptables stop
iptables: Flushing firewall rules:                         [  OK  ]
iptables: Setting chains to policy ACCEPT: filter          [  OK  ]
iptables: Unloading modules:                               [  OK  ]

启动svn服务

[root@svn ~]# svnserve -d -r /data/svn/
[root@svn ~]# netstat -anpt |grep svn
tcp        0      0 0.0.0.0:3690                0.0.0.0:*                   LISTEN      1721/svnserve

四、测试

在windows上安装好svn客户端,并检出svn版本库

如下图,图中的svn地址是通过http协议组成的,repos是/etc/httpd/conf.d/subversion.conf定义的,test则是svn版本库下面的一个代码库

技术分享

技术分享

技术分享

这样我们就检出了版本库test,现在我们在客户端添加一个文件并提交上去

新建文件test.txt,并使用lyao用户提交,这个用户默认情况是我们没有设置写权限

技术分享

技术分享

从上图中我们能看到出现403 forbidden错误,表示该用户没有权限写入文件

我们再换weyee用户提交文件,这个用户对test版本库拥有写权限,提交后查看日志

技术分享

日志结果显示weyee用户能正常提交test.txt文件。

测试2:多版本库的测试

我们在svn的根目录下创建一个版本库yanfa

[root@svn svn]# pwd
/data/svn
[root@svn svn]# svnadmin create yanfa
[root@svn svn]# egrep -v "^$|^#" /data/svn/yanfa/conf/svnserve.conf 
[general]
anon-access = read
auth-access = write
password-db = /data/svn/passwd
authz-db = /data/svn/authz
[sasl]

#在认证文件中/data/svn/authz添加权限
[root@svn svn]# egrep -v "^#" /data/svn/authz 

[aliases]

[groups]
admin = weyee
yunwei = lyao


[test:/]
@admin = rw
@yunwei = r


[kaifa:/]
@admin = rw
@yunwei = r

[yanfa:/]        #对新加的yanfa版本库添加相应的权限
@admin = rw
@yunwei = rw

[root@svn svn]# chown -R apache.apache yanfa

在客户端检出版本库yanfa

技术分享

提交一个测试文件yanfa.txt,直接查看更新日志

技术分享

到此svn+apache的多版本库配置已完成


本文出自 “ly36843运维” 博客,请务必保留此出处http://ly36843.blog.51cto.com/3120113/1662304

svn+apache配置多版本库

标签:svn+apache配置多版本库

原文地址:http://ly36843.blog.51cto.com/3120113/1662304

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!