用 PHP 的 file_put_contents 函数以追加的方式,循环 10 w 次写文件,耗时很多。因为 file_put_contents 函数每次都要打开文件,写入文件,然后关闭文件。
以下是测试:
public function handle()
{
$testTxt = storage_path('test.txt');
for ($i = 0; $i < 100000; $i++) {
$this->comment('writing...');
file_put_contents($testTxt, 'wo shi tanteng.' . PHP_EOL, FILE_APPEND);
}
$this->comment('time:' . round(microtime(true) - LARAVEL_START, 2));
}
如图所示:
耗时 165.76 秒。现在换一种写文件的方式,使用 fwrite 并且加锁的方式同样循环 10w 次写入,代码如下:
public function handle()
{
$testTxt = storage_path('test2.txt');
$handle = fopen($testTxt, 'wr');
flock($handle, LOCK_EX | LOCK_NB);
for ($i = 0; $i < 100000; $i++) {
$this->comment('writing...');
fwrite($handle, 'wo shi tanteng.' . PHP_EOL);
}
flock($handle, LOCK_UN);
fclose($handle);
$this->comment('time:' . round(microtime(true) - LARAVEL_START, 2));
}
运行效果如图:
如图所示,耗时 40.46 s,大大提高了效率。
跟 file_put_contents 函数比, fwrite 提高了写文件的效率,同时使用 flock 进行写文件加锁,防止并发同时操作一个文件。