作者:159dzhqian449_734 | 来源:互联网 | 2013-07-22 14:05
SVN的权限控制分为读取,写入(同时包含读取),无任何权限,也可以设置匿名用户,匿名通常只允许读取版本库。hooks的使用时为了我们方便同步更新。比如团队中有3个小组,每个小组做不同的模块,而部门经理通常需要查看完成的任务,以及完成的质量。于是通常我们会在web的根目录下面自动导入一个svn版本文件,用于同步更新3个小组提交的文件。这样我们就可以省略人工繁琐的导出操作。下面我们以图文的形式讲解如何实现以上两种需求。
-
SVN权限控制。首先我们需要启动SVN服务,然后创建一个版本库,导入我们的测试文件。由于此处已经做过教程所以略去
-
然后我们打开SVN权限的配置文件,在conf目录下面,这三个文件分布式存储权限,存储密码,以及总调度配置文件。
-
编辑配置文件,主要查看一下配置项:
a)、大约在19行20行,去除注释符号‘#’。anon-access = none不允许匿名访问,auth-access = write允许授权读写。
b)、大约在27行34喊,去除注释符号‘#’。password-db = passwd加载密码配置文件,authz-db = authz加载授权文件。这里的配置文件就是上图说明的那两个文件。
-
接下来配置密码文件,编辑passwd文件:在文件的最末尾追加admin = adminpass,意思是说用户名是admin,密码是adminpass。以后我们登陆到特定的svn服务器时需要用到。
-
最后我们需要配置权限文件,编辑authz文件:
a)、注意在21行左右groups分组,我们追加一个分组,名称administration = admin(多个用户用,分割),此处的意思是创建用户组administration并添加成员admin,就是我们在密码文件中添加的用户。
b)、然后我们在文件的末尾追加这个用户组的权限
第一行:对版本库SVN的控制有效,不过可能你创建的版本库不叫svn所以这里只是我的巧合,此处也可以用绝对路径
第二行:意思是administration用户组队版本库svn具有所有权限,此处的@符号不要忘记,此处也可以就写成admin因为这个组只有一个用户,完全是等价的
第三行:意思是所有其他用户具有读取权限
-
重启svn服务器,然后访问:输入用户名和密码之后就可以查看相应的版本库文件了,否则会出现验证用户失败。
-
hooks介绍,hooks中文叫做钩子,其实我们可以理解成一个Javascript触发事件,或者mysql的一个触发器。我们打开hooks文件夹:第一文件是我自己写的一个钩子文件,由于在windows中所以是一个批处理脚本内容如下
2
|
SET WORKING_COPY=D:\www\test
|
3
|
svn update %WORKING_COPY% –-username admin –-password admin
|
钩子分为:提交完成,提交开始,提交之前等。我们这里测试的是提交完成之后执行的钩子脚本post-commit
-
将上面的批处理脚本保存为post-commit.bat保存在hooks目录下面,然后我们从svn目录下导出两个副本test(假如我们的版本库已经存在test文件),一个放在WWW目录下面,一个导出在桌面。然后我们修改桌面的test的文件,提交至svn服务器,再查看www目录下的的test副本也自动更新了。注意此处存在几点容易失败,第一脚本错误,第二没有权限,通常需要修改svn服务启动的用户,通常与登录一致。如果是系统用户也可能存在失败的现象,至于什么原因我也没搞清楚,系统用户大于administration的用户权限,但是就是不可以。会出现堵死卡主的现象。注意我们这里说的服务器端钩子脚本,并不是客户端钩子脚本。