先说说钩子是干什么的吧,,简单的说,svn钩子就是在提交svn时前后所要触发的事件,于是我们可以用钩子做一些提交时的限制,及提交后的操作。最常用的一般有两个,pre-commit,post-commit。下面分别简单说下概念。
一、钩子概述
1)start-commit — 开始提交的通知
描述
start-commit 在开始事务之前执行。通常用来确定用户是否有提交权限。
如果 start-commit 钩子程序返回非零值,提交就会在创建事务之前停止,stderr 的任何输出都会返回到客户端。
输入参数
传递给你钩子程序的命令行参数,按照顺序是:
1.版本库路径
2.认证过的尝试提交的用户名
3.Colon-separated list of capabilities that a client passes to the server, including depth, mergeinfo, and log-revprops
2)pre-commit — 在提交结束之前提醒。
描述
pre-commit 钩子在事务创建新版本之前运行。通常这个钩子是用来保护因为内容或位置(例如,你要求所有到一个特定分支的提交必须包括一个 bug 追踪的 ticket 号,或者是要求日志信息不为空)而不允许的提交。
如果 pre-commit 钩子返回非零值,提交会终止,提交事务被删除,所有 stderr 的输出会返回到客户端。
输入参数
传递给你钩子程序的命令行参数,按照顺序是:
1.版本库路径
2.提交事务的名称
3)post-commit — 成功提交的通知。
描述
post-commit 钩子在事务完成,创建新版本后执行。大多数人用这个钩子来发送关于提交的描述性电子邮件,或者用来提醒其它工具(例如问题跟踪),发生了提交动作。一些配置也使用这个钩子触发版本库的备份进程。
如果 post-commit 钩子返回非零值,提交不会终止,因为它已经完成。然后,所有 stderr 的输出都会返回到客户端,让诊断钩子的失败更容易。
输入参数
传递给你钩子程序的命令行参数,按照顺序是:
1.版本库路径
2.提交创建的修订版本号
二、pre-commit钩子举例说明
1、此脚本会在提交前对事件进行检查
[[email protected]_11 test]# cat /svndata/test/hooks/pre-commit
#!/bin/sh
REPOS="$1"
TXN="$2"
export LANG=en_US.UTF-8
MAX_SIZE=5242880000
FILTER=‘\.()$‘
SVNLOOK=/usr/bin/svnlook
AUTHORS=‘(tao|wang)‘
LOGMSG=`$SVNLOOK log -t "$TXN" "$REPOS" |wc -c` ; 判断输入log的最小字符,小于10个不让提交
if [ $LOGMSG -lt 10 ];then
echo -e "log message can‘t be empty or less 9 chars as commit!" >&2
exit 1
fi
SVNUSER=`$SVNLOOK author -t "$TXN" "$REPOS"` ; 限制提交用户,不是脚本定义的用户不让提交,不过基本svn权限配置文件就够了。
if echo $SVNUSER |/bin/grep -vEq $AUTHORS ;then
echo -e "Sorry you no be author" >&2
exit 1
fi
File=$($SVNLOOK changed -t $TXN $REPOS|cut -d " " -f 4-) ; 限制提交文件的类型
echo "$File" |while read f;do
if echo $f |tr A-Z a-z|grep -Eq $FILTER;then
echo "File $f is not allow $FILTER file" >&2
exit 1
fi
FilesSize=`$SVNLOOK cat -t "$TXN" "$REPOS" "$f" |wc -c` ; 限制单个文件提交的大小
if [ "$FilesSize" -gt "$MAX_SIZE" ];then
echo "File $f is too large(must <=$MAX_SIZE)B" >&2
exit 1
fi
done
======================
提示:将以上脚本放到版本库的hooks下,并给执行权限,将提交时如果有符合以上限制,将限制提交。这里就不作测试,可自行测试,很简单。
======================
二、post-commit钩子举例说明
post-commit是在提交后进行的操作事件,用这个我们可以实现两个SVN服务器的时时同步,保持版本库的最新,或一些其他的方案,这里我只提供时时同步脚本。
环境:两台SVN服务器,版本库全部相同。并且两台配置SSH无密钥登陆。
说明:这里只在一台SVN上操作,另一台操作完全一样。
脚本原理:
1)先通过ssh远程执行无端SVN服务器中svn版本库的版本号和当前SVN服务器SVN版本库的版本号做对比。
2)对比完后,当前的SVN版本库最新大于远端SVN版本号,并通过svnadmin做增量备份。
3)备份完再通过ssh传到远端SVN服务器上,将增量备份进行还原操作
下面的脚本只是简单的实现,并未做完善,大家可以自己写更好的脚本实现,这里只是说明一个思路而已。
[[email protected]_11 test]# cat /svndata/test/hooks/post-commit
#!/bin/sh
REPOS="$1"
REV="$2"
SVNLOOK=/usr/bin/svnlook
R_ID=`/usr/bin/ssh [email protected] "$SVNLOOK youngest /svndata/test/"`
L_ID=`$SVNLOOK youngest $REPOS`
[ "$R_ID" -eq "$L_ID" ] && {
echo "The ID is neweast!!" >>/root/a.log
}
[ "$R_ID" -gt "$L_ID" ] && {
echo "Warning The R_ID is Biger than L_ID" >>/root/a.log
}
[ "$R_ID" -lt "$L_ID" ] && {
R_ID_1=$((${R_ID}+1))
sleep 1
/usr/bin/svnadmin dump --incremental -r ${R_ID_1}:${L_ID} /svndata/test >/root/svn_inter_bak/test_${R_ID_1}:${L_ID}
[ $? -ne 0 ] && {
echo "bakcup test dump failed" >>/root/a.log
}||{
echo "test dump is OK" >>$LOGS/a.log
sleep 1
}
/usr/bin/scp /root/svn_inter_bak/test_${R_ID_1}:${L_ID} [email protected]:/root/svn_inter_dir/
[ $? -eq 0 ] && {
# /usr/bin/ssh [email protected] "/bin/sh /root/svn_inter_restore.sh"
ssh [email protected] "/usr/bin/svnadmin load /svndata/test < /root/svn_inter_dir/*"
ssh [email protected] "/bin/rm -f /root/svn_inter_dir/*"
}||{
echo "warning..scp remote is failed" >>/root/a.log
}
}
====================完=============================