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

这样的确不会出现丢日志的问题

但问题来了,在并发下,导致接口响应速度极慢

所以又删了

慎用

相关推荐
不会写DN2 小时前
PHP 中的文件读写与上传
android·开发语言·php
hangbobo6 小时前
宝塔面板 PHP 7.4 安装 swoole_loader 解密扩展
php·swoole·宝塔面板
xingxin327 小时前
PHP代码分析溯源(第3题)
安全·web安全·网络安全·php
桌面运维家8 小时前
BGP路由优化实战:加速收敛,提升网络稳定性
网络·windows·php
m0_7381207210 小时前
我的创作纪念日0328
java·网络·windows·python·web安全·php
未来转换10 小时前
计算机网络基础之IP地址详解
tcp/ip·计算机网络·php
Leventure_轩先生12 小时前
[RL]强化学习指导搭建IC2E核反应堆
开发语言·php
a8a30213 小时前
IPV6公网暴露下的OPENWRT防火墙安全设置(只允许访问局域网中指定服务器指定端口其余拒绝)
服务器·安全·php
zhangren0246816 小时前
Laravel6.x核心特性全解析
开发语言·c++·php
小宇的天下16 小时前
Calibre LVS Circuit Comparison(3)
开发语言·php·lvs