Logrotate는 코드 1 및 CodeIgniter 2로 종료됩니다.

Logrotate는 코드 1 및 CodeIgniter 2로 종료됩니다.

CodeIgniter가 날짜별로 이름이 지정된 로그 파일에 쓸 때 가짜 로그 파일 "log.php"를 사용하고 있습니다.

/home/boxu/website/html/protected/application/logs/log.php {
        daily
        rotate 31
        missingok
        notifempty
        su boxu boxu
        #create 640 boxu boxu
        nocreate
        nocompress
        extension .php
        dateext
        dateformat -%Y-%m-%d
}

이것이 logrotate가 코드 1로 종료된 이유일까요?

 rotating pattern: /home/boxu/website/html/protected/application/logs/log.php  after 1 days (31 rotations)
empty log files are not rotated, old logs are removed
considering log /home/boxu/website/html/protected/application/logs/log.php
  log needs rotating
rotating log /home/boxu/website/html/protected/application/logs/log.php, log->rotateCount is 31
Converted ' -%Y-%m-%d' -> '-%Y-%m-%d'
dateext suffix '-2017-03-27'
glob pattern '-[0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9]'
removing /home/boxu/website/html/protected/application/logs/log-2017-02-24.php
removing old log /home/boxu/website/html/protected/application/logs/log-2017-02-24.php
destination /home/boxu/website/html/protected/application/logs/log-2017-03-27.php already exists, skipping rotation

마지막 줄이 의심스럽네요. -v를 사용하여 실시간으로 실행됩니다.

감사해요.

답변1

/*
a php solution
$dirin the directory to check
$numToKeep - keep the latest X number of files
*/
function cleanUpFiles($dirin,$numToKeep) {
    // 1- get a list of file for the directory

    $f1 = new FilesystemIterator($dirin , FilesystemIterator::SKIP_DOTS);
    gjLog($dirin . " number of files : " . iterator_count($f1),'clean.log');

    $gjcount=0; // start at

    if(iterator_count($f1) < $numToKeep){
        gjLog('Number of Files less than number to keep: ' . $numToKeep. ' Nothing to unlink' .PHP_EOL,'clean.log');
        return;
    }

    // 2- create an array of files to sort by Modified Time in step 3

    $thefiles = array();
    foreach($f1 as $fileinfo) {
        $akey = $f1->getFileName();
        if((strtolower($akey)) != 'index.html') {
            $thefiles[$akey] = $f1->getMTime();
        }
    }

    // 3- sort the files by date - descending  newest first

    arsort($thefiles);

    // 4- start at 0, after 10 files delete the rest

    foreach ($thefiles as $key => $value) {
        if($numToKeep < $gjcount){
            $killme = $dirin . DIRECTORY_SEPARATOR . $key;
            gjLog('unlinking these files: ' . $killme ,'clean.log');
            if(!unlink($killme)) {
                $err ='unable to unlink '. $killme .PHP_EOL;
                gjLog($err,'clean.log');
                // when in cron job, I check for Fatal in the mail
                echo $err. ' Fatal Error in' . __FILE__ . PHP_EOL;
            }
        }
        $gjcount++;
    }
}

// cleanup application logs

$dirin = '/var/www/html/application/logs';
$numToKeep=30; // total number to keep
cleanUpFiles($dirin,$numToKeep);
</pre>

관련 정보