使用小乌龟或者svn命令提交时,文件实际已经提交完毕,但需要等待很长的时间才提示提交完毕(几秒到十几秒不等,正常情况只要文件上传完了就提示提交完毕)。
我的项目大概100多M,android项目、ios项目、UI文档合计1G左右,当时就怀疑是钩子的原因,导致commit速度下降。
思路:每次提交时把需要修改的文件写入日志文件中,然后通过php读取日志文件 每次只用更新提交的文件,而不用更新整个项目
直接上代码
post-commit
#!/bin/shexport LANG=en_US.UTF-8REPOS="$1"REV="$2"SVN=/usr/bin/svnWEB=/Data/wwwrootLOG_FILE=/Data/logs/svn.logchanged=$(svnlook changed -r $REV $REPOS) # 比较改变的文件echo "$changed" >> $LOG_FILEphp svn_post_commit.php #执行php脚本php代码
<?php//读取日志文件$f = file_get_contents('/Data/logs/svn.log');$files = explode("/n", $f);if (!is_array($files)) { $files=(array)$files;};foreach ($files as $v) { // 取文件名 $f_tem = trim(substr($v, 2)); //由于只需要更新php代码,这里只拿到服务端代码 更新到www目录 $d_tem = substr($f_tem, 0, strpos($f_tem, '/')); if (!in_array($d_tem, array('www'))) { continue; } // SVN copy 对应的文件 $f_name = '/Data/wwwroot/' . str_replace('www/','',$f_tem); $cmd = "svn update '$f_name'"; //执行svn命令 exec($cmd,$out); //设置文件权限 exec("chown www:www $f_name");}//删除日志文件unlink("/Data/logs/svn.log");exit();新闻热点
疑难解答