PHP gzuncompress 出现文件读写错误

标签 php file-io event-log compression

我有一个函数可以跟踪脚本中发生的事件。为了有效地利用我的资源,我决定压缩它生成的数据。但是,我不断收到此错误:

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);
    }
}

因此,每天午夜,当上述任何事件(帐户、运行、队列、系统)发生时,都会创建一个新的错误日志,否则每个新事件都会附加到相应的日志文件中。

我很想保留压缩,但我不能继续出现这些错误,有人可以帮忙吗?提前致谢。

最佳答案

我认为实现是完全错误的,我不会建议你 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);

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

关于PHP gzuncompress 出现文件读写错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9768237/

相关文章:

python - 如何在pandas.read_csv的 header 之前跳过未知数量的空行?

c# - 启动时打开文件

c# - 无法将事件源重新注册到新的自定义事件日志

vbscript - 如何使用 vbscript 编写事件日志

powershell - 如何使用 Powershell 读取登录事件并查找用户信息?

php - 尝试获取YouTube视频标题和描述

php - 安装锂 php 框架

php - 如何转义 MYSQL 查询中的引号?

php - mgp25 - 新 Whatsapp 版本的 Whatsapi 注册问题