以http,svn两种模式访问svn库
以http,svn两种方式访问svn库
在[url] http://room-bb.iteye.com/blog/2190213[/url]搭建svn服务器这一文中,是通过svn:// 方式来访问svn仓库的。本文着重介绍通过apache配置,以http方式来访问版本库(这对于svn版本库部署在外网服务器上很有用)
1:创建多个svn仓库
2:配置svn
我们创建了三个svn仓库,可以把其中一个仓库的/data/svn/exam_1/conf目录下的配置文件移到 /data/svn/conf,这样可以通过一份配置,控制三个仓库的权限,具体操作如下:
3:启动svn 注意参数噢,很重要
4:配置svn支持http访问
5:关闭 SELinux。这个很重要,我就是没关闭,导致一直登陆不了,调试了一整天,都是泪啊
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的端口是否开放
在[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的端口是否开放