在开发过程中,经常会需要做批量处理,例如数据同步或格式转换时往往涉及大批量的数据处理,由于数据量大,数据里往往存在各种的差异,导致运行过程容易出问题,所以能在运行过程中实时输出每条记录运行的情况(成功或失败,失败的原因及引发异常的原始数据信息)是非常有助于排查问题的,我这里分享两个自己做了简单封装的方法,我自己觉得很好用,希望也对你们有用。
先做一下简单的说明:第一个方法是在你需要实时输出的方法最前面调用;第二个方法是需要输出内容时再调用,举个例子:
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的工具类里的,建议你可以把这两个方法也放到你自己的工具类里,使用起来就非常方便了。
看到了吗? 就是这么简单,如果好用,记着回来点个赞,哈哈