当前位置: 首页 > news >正文

file_put_contents锁的问题

记一次线上生产file_put_contents锁的问题
php项目,很多地方加了日志记录,方法为

function logstr($name='log',$str="",$type="Ymd"){$file = date("$type").'_'.$name.'.log';$add = __DIR__.'/../runtime/cuslog/'.date("Ym").'/';if(!is_dir($add)){mkdir(iconv("UTF-8", "GBK", $add),0777,true);}$file  = $add.$file;$content=['name'=>$name,'premsg'=>'','time'=> date('Y-m-d H:i:s'),'content'=>$str];file_put_contents($file, json_encode($content,JSON_UNESCAPED_UNICODE|JSON_UNESCAPED_SLASHES).PHP_EOL,FILE_APPEND);
}

忽然有天查日志,发现日志有丢失问题,在并发情况下,有些日志没有没记录下来
所以加了下锁 LOCK_EX
变为

file_put_contents($file, json_encode($content,JSON_UNESCAPED_UNICODE|JSON_UNESCAPED_SLASHES).PHP_EOL,FILE_APPEND|LOCK_EX);

这样的确不会出现丢日志的问题
但问题来了,在并发下,导致接口响应速度极慢
所以又删了
慎用

http://www.lryc.cn/news/232955.html

相关文章:

  • 工作中积累的对K8s的就绪和存活探针的一些认识
  • 什么是会话固定以及如何在 Node.js 中防止它
  • 代码随想录算法训练营第五十二天|300. 最长递增子序列、674. 最长连续递增序列、718. 最长重复子数组
  • 使用 Hugging Face Transformer 微调 BERT
  • Vue原型对象
  • 向量数据库的分类概况
  • 工业镜头的类别
  • 实验11 SQL互联网业务查询-2
  • C++知识点梳理:C++ templates
  • uniapp form表单提交事件手动调用
  • Accelerate 0.24.0文档 三:超大模型推理(内存估算、Sharded checkpoints、bitsandbytes量化、分布式推理)
  • HackTheBox-Starting Point--Tier 2---Markup
  • android studio导入eclipse项目
  • 如何利用AI实现银行存量客户的营销?
  • springboot327基于Java的医院急诊系统
  • Unity3d 导入中文字体转TMPtext asset
  • 云积万相,焕发电商店铺新活力
  • 字典管理怎么使用,vue3项目使用若依的的字典管理模块
  • 【汇编】内存中字的存储、用DS和[address]实现字的传送、DS与数据段
  • 数据分析 - 分散性与变异的量度
  • Neo4j数据库介绍及简单使用
  • ubuntu 20.04安装 Anaconda教程
  • iframe渲染后端接口文件和实现下载功能
  • 广西建筑工地模板:支模九层桉木模板
  • java集合,栈
  • Ubuntu 20.04 LTS ffmpeg gif mp4 互转 许编译安装ffmpeg ;解决gif转mp4转换后无法播放问题
  • 【Nginx】使用nginx进行反向代理与负载均衡
  • 基于IDEA 进行Maven依赖管理
  • 瑞萨RZ/G2L平台 初起动(SD卡启动)
  • chkconfig及服务脚本