设为首页 收藏本站
查看: 885|回复: 0

[经验分享] Subversion+apache搭建svn服务器

[复制链接]

尚未签到

发表于 2017-1-7 10:29:12 | 显示全部楼层 |阅读模式
1.安装subversion 和subversion-tools
#aptitude install subversion subversion-tools

安装完成后,用如下命令应该可以看到相关的帮助
#svn help

2.新建库代码存储库,也就是常说的代码仓库,以后的项目可以上传到这个仓库里
假设我现在要把我的库仓库在/data/svn目录下,库名为:repository

#mkdir /data/svn
#svnadmin create /data/svn/repository
此时已经在/data/svn目录下创建一个名为repository的空库

然后用如下命令查看这个库里的内容
#svn list file:///data/svn/repository
可以发现里面空的

到第2步为止,subversion的安装,建库已经完成。
但是一般都是搭配apache,这样才可以用http协议来访问subversion,
这里我们选择apache2

3.安装apache2和libapache2-svn
#aptitude install apache2
#aptitude install libapache2-svn


chown -R www-data.www-data /data/svn

4.修改apche2的配置文件
#vim /etc/apache2/mods-available/dav_svn.conf
打开这个文件后,发现这个文件里的内容全被注释掉了,把注释拿掉,留下如下部分
<Location /svn>
DAV svn
SVNParentPath /data/svn
AuthType Basic
AuthName "Subversion Repository"
AuthUserFile /etc/apache2/dav_svn.passwd
AuthzSVNAccessFile /etc/apache2/dav_svn.authz
Require valid-user
</Location>

对此文件做一个解释:
SVNParentPath /data/svn,这里的/data/svn为你刚建的svn代码仓库的代目录,也就是repository的你目录/data/svn

AuthUserFile /etc/apache2/dav_svn.passwd:因为我们登陆svn的时候需要用户名和密码的验证,我们会把所有用户的用户名和密码存储在/etc/apache2/dav_svn.passwd这个文件里,然后当用户访问的时候会首先把用户的用户名和密码与dav_svn.passwd里的信息进行对比

AuthzSVNAccessFile /etc/apache2/dav_svn.authz:如果用户名密码验证过后,就要对目录进行验证。所谓 目录进行验证 就是说 一个代码仓库里可能有很多项目,很多目录,一些目录 可能只允许一部分可以read,都者一部分可以read ,write这些权限的配置信息就是保存在/etc/apache2/dav_svn.authz文件里

5.第4步有提到当一个用户登陆时,会把用户的用户名和密码与/etc/apache2/dav_svn.passwd里的内容进行对比,也就是说用户名和密码是存储在/etc/apache2/dav_svn.passwd这个文件里。那这些用户名和密码是怎么放进去的呢?

可以用apache2的一个生成用户名和密码的工具htpasswd进行,
假设要创建一个用户名为"bevisoft"的用户 ,命令行如下:
#htpasswd /etc/apache2/dav_svn.passwd bevisoft
然后会提示你输入密码.
这里要特别注意,这个命令还有一个参数 -c
也就是说
#htpasswd -c /etc/apache2/dav_svn.passwd bevisoft
"-c"的意思就是说创建/etc/apache2/dav_svn.passwd 这个文件。如果/etc/apache2/dav_svn.passwd 这个文件存在了,就不要用"-c"


6.第4步也有提到,关于目录里各个项目的权限的配置是保存在:/etc/apache2/dav_svn.authz这个文件
/etc/apache2/dav_svn.authz文件的格式如下:

[groups]
admin=bevisoft
project1group = user1,user2

[/]
*=
[repository:/]
*=
@admin=rw

[repository:/project1]
@project1group = rw
*=


对上面这个文件做一下解释:
紧跟[groups]后面的信息是创建群组,因为所有的成员基本都是以项目组的方式进行,一般一个项目组的所有成员都拥有相同的权限,这样对权限分配也会容易一些

[/]
*=
[repository:/]
*=
@admin=rw

[repository:/project1]
@project1group = rw
*=
这一段就是控制各个项目的权限:
svn代码库的根目录任何人都没有权限,所以用到
[/]
*=
而admin这个group里的成员有对repository仓库的所有项目的权限,所以用到
[repository:/]
*=
@admin=rw

project1这个项目只能是project1group的成员有read ,write的权限,所以用到
[repository:/project1]
@project1group = rw
*=

7. 做到以上6步后还差最后一步:因为我们是通过apache2来与subversion交互
那么我们要让apache2的用户www-data对subversion这个目录有操作权限
#chown -R www-data.www-data /data/svn/repository
我一般还会加一条:
#chown -R www-data.www-data /data/svn

因为在我在架apache2+subversion的时候,先是用
#chown -R www-data.www-data /data/svn
结果我访问不成功,后来又加了一句
#chown -R www-data.www-data /data/svn/repository
结果就成功了!

以上是我自己实践的一个记录,^^

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-325006-1-1.html 上篇帖子: Apache+Tomcat集群配置 基于最新的Apache和Tomcat(测试过Ok) 下篇帖子: apache commons-vfs源码赏析(二)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表