以http,svn两种方式访问svn库

  在[url] http://room-bb.iteye.com/blog/2190213[/url]搭建svn服务器这一文中,是通过svn:// 方式来访问svn仓库的。本文着重介绍通过apache配置,以http方式来访问版本库(这对于svn版本库部署在外网服务器上很有用)

1:创建多个svn仓库
svnadmin create /data/svn/exam_1
svnadmin create /data/svn/exam_2
svnadmin create /data/svn/exam_3

注意,你也可以不用执行多次svnadmin 其实创建了一个exam_1,可以直接cp -r exam_1 exam_2


2:配置svn
我们创建了三个svn仓库,可以把其中一个仓库的/data/svn/exam_1/conf目录下的配置文件移到 /data/svn/conf,这样可以通过一份配置,控制三个仓库的权限,具体操作如下:
mkdir -p /data/svn/conf
cp -r /data/svn/exam_1/conf/* /data/svn/conf

配置passwd
vi /data/svn/conf/passwd
manager = 123456
dev1 = 123456
dev2 = 123456
dev3 = 123456

art1 = 123456
art2 = 123456
art3 = 123456

des1 = 123456
des2 = 123456
des3 = 123456

配置authz
vi /data/svn/conf/authz
admin = manager

dev = dev1,dev2,dev3

art = art1,art2,art3

des = des1,des2,des3

[/]
@admin = rw
* =

[exam_1:/]
@admin = rw
@dev = rw
* = 

[exam_2:/]
@admin = rw
@art = rw
* = 

[exam_3:/]
@admin = rw
@des = rw
* =

配置全局文件 svnserve.conf
vi /data/svn/conf/svnserve.conf
anon-access = none  #禁止匿名访问,设置为none。默认为read,参数:read,write,none
auth-access = write #授权用户写权限

password-db = /data/svn/conf/passwd
authz-db = /data/svn/conf/authz

realm = svn #每个SVN项目的认证名,会在认证提示里显示,建议写项目名称。

 
  3:启动svn 注意参数噢,很重要
svnserve -d -r /home/svn --config-file /data/svn/conf/svnserve.conf 


  4:配置svn支持http访问
生成账号密码认证文件
htpasswd -cm /data/svn/conf/http_passwd manager #第一次生成要参数-c
htpasswd -m /data/svn/conf/http_passwd dev1 #后面添加的用户不要带参数-c

http_passwd 是http模式下使用的认证文件,passwd是svn模式使用的认证文件,
这两个文件中的用户和密码最好一样,这样,同一个用户可以用两种方式访问svn库

设置apache svn配置文件
cd /etc/httpd/conf.d/

如果没有subversion.conf 文件,那么先执行 yum -y install mod_dav_svn
vi /etc/httpd/conf.d/subversion.conf
<Location /svn> #/svn是虚拟目录,映射到/data/svn中。
   DAV svn
   
        #SvnPath /data/svn/ #只支持一个主目录的SVN版本库
        SVNParentPath /data/svn/ #支持多个相同父目录的SVN版本库

   # Limit write permission to list of valid users.
   #<LimitExcept GET PROPFIND OPTIONS REPORT>
      # Require SSL connection for password protection.
      # SSLRequireSSL

      AuthType Basic
      AuthName "Authorization SVN"
      AuthzSVNAccessFile /data/svn/conf/authz
          AuthUserFile /data/svn/conf/http_passwd
          Require valid-user
   #</LimitExcept>
</Location>

设置权限目录
  chown -R apache:apache /data/svn/

 重启apache服务
  service httpd restart


5:关闭 SELinux 。这个很重要,我就是没关闭,导致一直登陆不了,调试了一整天,都是泪啊
getenforce          ##查看SELinux状态
setenforce 0        ##设置SELinux  为permissive模式 不用重启,立即生效
                    ##setenforce 1 成为enforcing模式

vi /etc/selinux/config
将SELINUX=enforcing改为SELINUX=disabled 重启机器后生效



6:测试
svn方式访问:
在windows下,通过svn客户端输入
svn://192.168.7.223/exam_1

http方式访问
在浏览器地址栏输入
http://192.168.7.223/svn/exam_1
注意:这里比svn方式方位多了个/svn,因为我们配置location时设置了一个虚拟路径

如果想通过域名访问
例如
http://www.bb.com/svn/exam_1

修改hosts文件
vi /etc/hosts
192.168.7.223 www.bb.com

如果无法登录,要检查防火墙设置啦,iptables -L -n
查看svn和httpd的端口是否开放

猜你喜欢

转载自room-bb.iteye.com/blog/2293178