Linux CentOS下配置SVN+SVN勾子
环境介绍:
操作系统:CentOS release 6.5 (Final) 64位
网络环境:内网
1 配置SVN
1.1 安装SVN组件包
使用yum安装svn所需的组件包
# yum –y install subversion
1.2 配置SVN
1.2.1 创建svn库路径
创建svn库路径,该目录后期提供用户文件写入和读取。
# mkdir -p /date/svn/
1.2.2 创建SVN版本库
使用特定的命令来创建版本库,创建成功后该目录会出现SVN配置文件。
# svnadmin create /date/svn/
1.2.3 定义配置文件
#vim /opt/svndata/repos1/conf/svnserve.conf
[general]
anon-access = none
auth-access = write
password-db = passwd #定义用户密码的配置文件
authz-db = authz #定义用户权限的配置文件
realm = svn
1.2.4 用户权限配置
1、创建svn访问用户
#vim /data/svn/passwd
[users]
test = test 创建了一个叫tset密码为test的用户
2、配置用户访问权限
#vi /opt/svndata/repos1/conf/authz
[groups]
admin = test
# harry_and_sally = harry,sally
[/]
@admin = rw
[repos1:/abc/aaa]
@admin = r
版本库目录格式:
[<版本库>:/项目/目录] #是以项目名作为第一个单位。试想肯定是以项目为单元的
@<用户组名> = <权限>
<用户名> = <权限>
其中,方框号内部分可以有多种写法:
/,表示根目录及以下。根目录是svnserve启动时指定的,我们指定为/opt/svndata。这样,/就是表示对全部版本库设置权限。
repos1:/,表示对版本库1设置权限
repos2:/abc, ,表示对版本库2中的abc项目设置权限
repos2:/abc/aaa, ,表示对版本库2中的abc项目的aaa目录设置权限
权限主体可以是用户组、用户或*,用户组在前面加@,*表示全部用户。权限可以是w、r、wr和空,空表示没有任何权限。
1.2.5 启动SVN
# svnserve -d -r /date/svn/
-d表示以daemon方式(后台运行)运行
-r /date/svn指定根目录是/date/svn
1.3 配置钩子
1.3.1 配置版本检测工具
自己利用python写了一个自动检测库里面文件版本的工具。代码如下:
# vim /date/svn/hooks/gouzi.py
#!/usr/bin/env python
if __name__=='__main__':
importsys,string
try:
logfile= open('/tmp/python.out','a+')
logfile.write("this is python hook")
logfile.close()
except:
exit(1)
sys.exit(0)
此工具需放在库目录中的hooks目录中。
1.3.2 配置UPDATE脚本
1、首先在客户端上手工checkout一次
# svn checkout svn://192.168.21.28/repos
2、编辑自动同步脚本
# vim svn_update.sh
代码如下
#!/bin/bash
/usr/bin/svn update /linshi/repos --username test --password test
if [ $? == 0 ]
then
echo "ok" >> /tmp/z.out
fi
其中:/linshi/为存放目录(看环境而定)
--username test 用户名为test
--password test 密码为test
3、修改权限
# chmod +x /root/svn_update.sh
4、配置计划任务
因脚本无法实现自动执行,故配置计划任务设置每分钟执行一次。
# crontab -e
* * * * /root/svn_update.sh > /dev/null 2>&1
相关推荐
pub_svnserve.conf的 pub_authz.conf的配置文件有非法字符的原因引起,需要查找pub_authz.conf提的非法内容比如多余的空格删除或直接将pub_authz.conf