我有一个函数可以跟踪通过脚本发生的事件。为了有效利用我的资源,我决定压缩它生成的数据。不过,我不断收到此错误:带文件读写错误的PHP gzuncompress
Unknown error type: [2] gzuncompress() [function.gzuncompress]: data error
这里的功能:
function eventlog($type, $message){
// Types: account,run,queue,system
// Set up file name/location
$eventfile = '/myprivatedirectory/'.date('Ymd').$type.'.log';
if(file_exists($eventfile)){
while(!is_writable($eventfile)){clearstatcache();}
$fh_log = fopen($eventfile,'r+');
flock($fh_log, LOCK_EX);
$logcontents = gzuncompress(fread($fh_log,filesize($eventfile)));
rewind($fh_log);
ftruncate($fh_log, 0);
$logcompressed = gzcompress($logcontents.$message."\n");
fwrite($fh_log,$logcompressed);
flock($fh_log, LOCK_UN);
fclose($fh_log);
} else {
$fh_log = fopen($eventfile,'w');
flock($fh_log, LOCK_EX);
$logcompressed = gzcompress($message."\n");
fwrite($fh_log,$logcompressed);
flock($fh_log, LOCK_UN);
fclose($fh_log);
}
}
所以每天,在午夜,如上述任何事件的发生创造了一个新的错误日志(帐户,运行,队列,系统),否则每个新事件都附加到尊重日志文件。
我很想保持压缩,但我不能有这些错误,任何人都可以请帮忙吗?提前致谢。
'file_put_contents'会为您节省很多麻烦。 – Jon 2012-03-19 10:12:54
我正在用'file_get_contents'来试试这个,至今没问题。 – 2012-03-19 21:17:52