svn进阶

用svn已经很久了,但我所在的技术环境比较简单,基本我一个人使用svn。最近进一步学习了一下。以前对分支、标记知道,但不理解,也没时间管他,现在也算了解清楚了。

推荐的svn目录结构:
trunk主干
branches分支
tags标记

这些规则对于svn是没有意义的,只是一个规约。开发人员遵循即可。

分支就是根据项目需要,分理处一个特殊功能的代码,进行持续开发。

标记是一个快照,复制出来就不能再提交了。但这也是一个规约,强行提交还是可以的。
用tortoiseSVN的话在tags上进行提交会谈出警告。

主干就是正常开发代码分支,当然项目大了,在分支和标记外,还可以有很多很多的小的开发分支,基本功能实现差不多了,再合并到trunk。各个小分支可以给各个开发小组使用。

svn服务器内部对分支的实现是类似文件系统软连接的形式。所以不占什么空间。
对于分支所提供的命令也就只有copy和merge两个。

合并操作是在本地工作文件夹进行的。

tortoiseSVN的版本图可以较好的显示版本关系,branches会伸出一条分支,而tags则只会用黄色方块标记在主分支上。再次声明一下tags和branches在服务端是一样处理的。


[b]关于权限[/b]

ssh+svn的方式权限管理是有些问题的。用户能够登录ssh,就能访问svn文件夹,那么无法对其进行基于代码路径的控制

唯有使用apache (ssl) + svn是功能最全的:
安装apache
安装svn,打开dav等参数,会将so文件放入/usr/local/libexec/

httpd.conf
	LoadModule dav_module modules/mod_dav.so
LoadModule dav_svn_module modules/mod_dav_svn.so
LoadModule authz_svn_module modules/mod_authz_svn.so
LoadModule ssl_module modules/mod_ssl.so


<Location /svn>
DAV svn
SVNPath /usr/local/svn
AuthType Basic
AuthName "Feloo Subversion Repository"
AuthUserFile /etc/svn-auth-file
Require valid-user
AuthzSVNAccessFile /usr/local/svn/conf/authz
</Location>


ssl配置(略)


密码:
htpasswd -cm /etc/svn-auth-file zh


配置authz,和svn+ssh一样

哇塞,好帅啊:
https://www.zeeeitch.cn/svn
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值