2020-11-13 17:16:19 1262次浏览 0条回答 0 悬赏 10 金钱

问题描述:

使用小乌龟或者svn命令提交时,文件实际已经提交完毕,但需要等待很长的时间才提示提交完毕(几秒到十几秒不等,正常情况只要文件上传完了就提示提交完毕)。

问题分析:

我的项目大概100多M,android项目、ios项目、UI文档合计1G左右,当时就怀疑是钩子的原因,导致commit速度下降。

解决办法:

思路:每次提交时把需要修改的文件写入日志文件中,然后通过php读取日志文件 每次只用更新提交的文件,而不用更新整个项目

直接上代码

post-commit

#!/bin/sh
export LANG=en_US.UTF-8
REPOS="$1"
REV="$2"
SVN=/usr/bin/svn
WEB=/Data/wwwroot
LOG_FILE=/Data/logs/svn.log
changed=$(svnlook changed -r $REV $REPOS) # 比较改变的文件
echo "$changed" >> $LOG_FILE

php 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();
    没有找到数据。
您需要登录后才可以回答。登录 | 立即注册
PHP学院的中学生
副总裁

PHP学院的中学生

注册时间:2018-10-23
最后登录:2024-04-07
在线时长:168小时1分
  • 粉丝29
  • 金钱4730
  • 威望30
  • 积分6710

热门问题