Heim > php教程 > PHP源码 > Hauptteil

Schreiben Sie Dateien unter einem bestimmten Grad an Parallelität auf die Festplatte

大家讲道理
Freigeben: 2016-11-09 10:11:55
Original
1336 Leute haben es durchsucht

<?php
 
function write_log($log_content)
{
    $log_file = &#39;/logs/error.log&#39;;
 
    if(is_file($log_file)) {
        // 检测log文件大小,将每个log文件控制在2m以内
        $log_filesize = filesize($log_file);
        $max_size = 2 * 1024 * 1024; // 可以接受的最大的文件大小
        if($log_filesize >= $max_size) {
            $new_log_file = &#39;/logs/error_&#39; . date(&#39;YmdHis&#39;) . &#39;.log&#39;;
            rename($log_file, $new_log_file);
        }
    }
 
    $fp=fopen($log_file,&#39;a+&#39;);
    if($fp){
        $startTime=microtime();
        do{
            // 这个循环可以保证进程在尝试1m后,如果未能锁定文件,则放弃写入日志的操作
            $canWrite=flock($fp,LOCK_EX);
            if(!$canWrite){
                usleep(round(rand(0,100)*1000));
            }
        }while((!$canWrite)&&((microtime()-$startTime)<1000));
        if($canWrite){
            $content = date(&#39;Y-m-d H:i:s&#39;) . &#39; &#39; . $log_content . "\r\n";
            fwrite($fp,$content);
        }
        fclose($fp);
    }
}
Nach dem Login kopieren

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Empfehlungen
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage