dongtao4890 2016-10-31 15:56
浏览 39
已采纳

PHP日志代码不稳定,有时只写

I created a logger method on a class, the basic logging code is this:

    // maximum length of file (in characters / bytes)
    $maxlength = 40000;
    $filename = "logs/$this->account_id.log";

    // add to the first line
    $fileContent = file_exists($filename) ? file_get_contents($filename, NULL, NULL, NULL, $maxlength) : "";
    file_put_contents($filename, '['.date('d-m-Y- H:i:s').'] - '.$message.PHP_EOL. $fileContent);

It makes sure the most recent log entries appear first. All works fine, except some messages are logged then reverted back to 3 days ago after a while.

File has write permissions, any ideas what could be going on?

  • 写回答

1条回答 默认 最新

  • dongyin4202 2016-10-31 16:14
    关注

    It is highly probable that it is a concurrency issue. You have a separate log file for each user, but a user might send several requests in a short period of time, reaching to the undesired result that several logs are issued in the same time. You need to form some kind of queue either in a database or a standalone service which will receive the messages and will be the only thing responsible to write into the log file.

    Example solution:

    • you create an RDBMS table user_log(account_id, message, timestamp) whenever a new log is needed. This will actually let the system know that you intend to store some logs
    • you create a cron job which will periodically see what users' log files need to be changed and change them
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 机器学习训练相关模型
  • ¥15 Todesk 远程写代码 anaconda jupyter python3
  • ¥15 我的R语言提示去除连锁不平衡时clump_data报错,图片以下所示,卡了好几天了,苦恼不知道如何解决,有人帮我看看怎么解决吗?
  • ¥15 在获取boss直聘的聊天的时候只能获取到前40条聊天数据
  • ¥20 关于URL获取的参数,无法执行二选一查询
  • ¥15 液位控制,当液位超过高限时常开触点59闭合,直到液位低于低限时,断开
  • ¥15 marlin编译错误,如何解决?
  • ¥15 有偿四位数,节约算法和扫描算法
  • ¥15 VUE项目怎么运行,系统打不开
  • ¥50 pointpillars等目标检测算法怎么融合注意力机制