svn钩子(hooks)

首先你需要搭建出自己的svn环境出来,并能成功导入导出,并且了解svn,这是看这篇文章的前提....

出于公司开发部需要svn同步更新服务器代码,需要用到svn钩子(hooks)技术,以前从来没听过,没办法只能google了,google半天再一次认同了一个道理:天下文章一大抄啊,东拼西凑终于算是完成了(为啥说算是呢?svn太强大了我所做的只是一点点),不多说了,上例子:

我们公司的部署很简单(svn服务和web服务在同一台主机上):

开发 ----- svn(存储)---- 线上服务器

以前是这样(没有用到hooks时):

开发部commit一个文件,线上服务的web文档并不同步,而是需要在svn服务上执行

svn update命令后才能同步。

现在是这样(用到hooks后):

开发部commit一个文件,线上服务(web目录)同步数据,不需要svn update命令了,这样就减少了中间的一个小繁琐,别看这只是一个小动作但是省了一大麻烦(对于web开发工程师来说尤其这样,你想啊,代码经常改,还得经常svn update,总是一件事来回来回,烦不烦啊,是吧!)

我们需要同步的网站目录是(当然之前在svn服务器上已经存有assets目录文件了):

svn钩子(hooks)

这样就先在webdir目录下建立一个assets目录(记得切换到webdir目录下),并运行

svn钩子(hooks)

那么怎么利用hooks实现数据同步呢?接下来

svn钩子(hooks)

看到了绿色文件了吗?!这里面其实就是一个shell脚本:

svn钩子(hooks)

其中的DIR变量存着需要同步的目录,利用svn update命令加上用户名、密码就能同步了(我做的也就只能这么简单,莫怪兄弟啊!),主要看上幅图,有很多.tmpl结尾的文件,这些就是hooks模板了,post-commit这个文件名不要更改(需要给它执行权限)

经过这几步后,不需要手动执行这个post-commit脚本就可以完成开发部所需要的要求了!

为什么这样呢?套用网上的话(我也抄了,sorry啊!):

post-commit
在提交完成,成功创建版本之后执行该钩子,提交已经完成,不可更改,因此本脚本的返回值被忽略。

post-lock
对文件进行加锁操作之后执行该脚本

post-revprop-change
在修改 revision 属性之后,执行该脚本。因为修改稿已经完成,不可更改,因此本脚本的返回值被忽略(不过实际上的实现似乎是该脚本的正确执行与否影响属性修改)

post-unlock
对文件进行解锁操作之后执行该脚本

pre-commit
在 Subversion transaction 完毕之后,在提交之前,执行该脚本

pre-lock
对文件进行加锁操作之前执行该脚本

pre-revprop-change
在修改 revision 属性之前,执行该脚本

pre-unlock
对文件进行解锁操作之前执行该脚本

start-commit
在客户端还没有向服务器提交数据之前,即还没有建立 Subversion transaction(缩写为 txn) 之前,执行执行该脚本

具体到我们的应用场景,我们要实现一个同步的测试服务器,我们只需要在一个用户执行完毕一个commit提交操作之后,让钩子程序去自动更新测试服务器的文件即可!

附上我所做的svn目录介绍:

192.168.1.20就是我们公司内部服务器了(svn+web),svn的根目录就是svndate(svndate就是版本目录了,直接用svn客户端访问192.168.1.20就行)

svn钩子(hooks)

他的auth文件是(这样就能看出来svndate就是根目录了,注意document目录,前面的图里面出现过):

svn钩子(hooks)

上一篇:BUG——Celery ValueError: not enough values to unpack


下一篇:Solr入门之(1)前言与概述