svn commit 提交很慢问题解决办法 [ 2.0 版本 ]
问题描述:
使用小乌龟或者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();
共 0 个回答
没有找到数据。
PHP学院的中学生
注册时间:2018-10-23
最后登录:2024-09-23
在线时长:168小时13分
最后登录:2024-09-23
在线时长:168小时13分
- 粉丝29
- 金钱4725
- 威望30
- 积分6705