2012-03-19 61 views
1

我有一个函数可以跟踪通过脚本发生的事件。为了有效利用我的资源,我决定压缩它生成的数据。不过,我不断收到此错误:带文件读写错误的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); 
    } 
} 

所以每天,在午夜,如上述任何事件的发生创造了一个新的错误日志(帐户,运行,队列,系统),否则每个新事件都附加到尊重日志文件。

我很想保持压缩,但我不能有这些错误,任何人都可以请帮忙吗?提前致谢。

+1

'file_put_contents'会为您节省很多麻烦。 – Jon 2012-03-19 10:12:54

+0

我正在用'file_get_contents'来试试这个,至今没问题。 – 2012-03-19 21:17:52

回答

1

我认为这个实现是错误的,我不会建议你使用gzcompress($ message。“\ n”);每封邮件......

,我认为你应该做的是,在这一天结束时,你可以压缩整个日志文件,这是更有效的

保存使用

file_put_contents 

您的信息在在一天结束的时候

$eventfile = '/myprivatedirectory/'.date('Ymd').$type.'.log'; 
$eventfileCompressed = '/myprivatedirectory/'.date('Ymd').$type.'.gz'; 
$gz = gzopen($eventfileCompressed ,"w9"); 
gzwrite($gz, file_get_contents($eventfile)); 
gzclose($gz); 

读取文件

$zd = gzopen($eventfileCompressed,"r"); 
$zr = gzread($zd,$fileSize); 
gzclose($zd); 

这种方法可以为您节省更多的处理能力

+0

你是对的,这是最好的选择,但是,我的所有cron斑点都已经满了,我只需要将它粘贴到另一个cron的末尾。 – 2012-03-19 21:18:57