在开发过程中,经常会需要做批量处理,例如数据同步或格式转换时往往涉及大批量的数据处理,由于数据量大,数据里往往存在各种的差异,导致运行过程容易出问题,所以能在运行过程中实时输出每条记录运行的情况(成功或失败,失败的原因及引发异常的原始数据信息)是非常有助于排查问题的,我这里分享两个自己做了简单封装的方法,我自己觉得很好用,希望也对你们有用。
先做一下简单的说明:第一个方法是在你需要实时输出的方法最前面调用;第二个方法是需要输出内容时再调用,举个例子:
public function testApi(){
Tools::realTimeOutputPrepare();
$i = 1;
while($i < 100){
sleep(1);
Tools::realTimeOutput($i++);
}
die;
}
这两个方法的具体内容是:
/**
* 实时输出内容准备(设置头部)
*/
public static function realTimeOutputPrepare(){
header('X-Accel-Buffering: no');
set_time_limit(0);
ob_end_clean();
ob_implicit_flush(1);
}
/**
* 实时输出内容(清理缓冲区)
*/
public static function realTimeOutput($string){
if(is_array($string)){
$string = Tools::arrayToJson($string);
}
echo $string."<br>";
flush();
}
我的方法是以静态方法的形菜定义到一个叫Tools的工具类里的,建议你可以把这两个方法也放到你自己的工具类里,使用起来就非常方便了。
看到了吗? 就是这么简单,如果好用,记着回来点个赞,哈哈