码迷,mamicode.com
首页 > 其他好文 > 详细

svn钩子(hooks)

时间:2014-08-02 12:12:03      阅读:213      评论:0      收藏:0      [点我收藏+]

标签:os   io   文件   数据   for   art   cti   ar   

首先你需要搭建出自己的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目录文件了):

bubuko.com,布布扣

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

bubuko.com,布布扣运行完这条命令后在webdir下面就检出了svn服务器上的assets目录了(里面有网站文件),这样做就相当于把web目录做成客户端目录了;

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

bubuko.com,布布扣

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

bubuko.com,布布扣

其中的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就行)

bubuko.com,布布扣

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

bubuko.com,布布扣

svn钩子(hooks),布布扣,bubuko.com

svn钩子(hooks)

标签:os   io   文件   数据   for   art   cti   ar   

原文地址:http://www.cnblogs.com/tdalcn/p/3886534.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!