>  기사  >  데이터 베이스  >  Redis는 로그와 인기 기사를 저장합니다.

Redis는 로그와 인기 기사를 저장합니다.

齐天大圣
齐天大圣원래의
2020-05-12 08:32:431961검색

PHP에서는 인덱스 배열로 간주할 수 있는 Redis의 목록 데이터 유형을 사용하여 다양한 데이터 구조를 구현할 수 있습니다. 스택, 큐, 메시지 큐 등 다양한 데이터 구조를 구현할 수 있습니다. 오늘은 Redis를 활용하여 시스템 로그와 인기글 목록을 저장하는 방법을 소개해드리고자 합니다.

로그 저장

우리 모두 알고 있듯이 nginx 로그는 기본적으로 자동으로 절단되지 않습니다. 로그 절단 작업은 항상 파일에 저장되고 추가되어야 합니다. nginx 외에도 로그는 여러 곳에서 사용됩니다. 문제가 발생하면 로그는 단서를 찾는 주요 방법 중 하나입니다.

이제 Redis에 시스템 로그를 작성할 계획입니다. 단일 로그 파일이 너무 커지는 것을 방지하기 위해 일일 로그가 목록에 기록됩니다.

기본 아이디어는 일일 로그 정보를 별도의 목록에 기록한 다음 예약된 작업을 수행하는 것입니다. 예약된 작업의 기능은 1개월 전의 로그 목록을 꺼내어 텍스트 파일로 유지하는 것입니다. 그런 다음 Redis가 너무 많은 메모리를 차지하는 것을 방지하기 위해 Redis에서 1개월 전의 로그 목록을 삭제합니다.

압축 기능을 이용하면 로그 정보를 압축하여 메모리 사용량을 줄일 수 있습니다. 또한 로그 목록의 키 이름을 쉽게 검색할 수 있도록 로그 목록의 키 이름을 저장하는 목록을 유지 관리합니다. 로그를 저장하는 의사코드는 다음과 같습니다.

$log = ... // 日志信息
// 日志列表键名
$key = 'log:'.strtotime(date('Y-m-d'));

// 维护一个键名列表
if (!$redis->exists($key)) {
 $listlogkey = 'log:key';
 $redis->rpush($listlogkey, $key);
}

// 日志信息存放到redis中
$redis->rpush($key, $log);

예약된 작업 코드는 다음과 같습니다.

$lastMonth = strtotime("-30 day");

while ($logkey =  $redis->lpop('log:key')) {
    $logTime = explode(':', $logkey)[1];
    
    if ($logTime < $lastMonth) {
        // 从日志列表里去日志信息,一次取50条
        for ($start = 0, $end = 49;true;$start +=50, $end+=50) {
            $logs = $redis->lrange($logkey, $start, $end);
            if (!$logs) break;
            // 将日志信息解压缩,然后追加写入文本文件中
             ……
             
            // 删除该日志列表
            $redis->del($logkey);
        }   
    } else {
        // 一个月之内的,重新push到左侧
        $redis->lpush(&#39;log:key&#39;, $logkey);
        exit;
    }
}

여기서 주의할 점이 몇 가지 있습니다. 영구 로그가 실패하거나 지난 달의 로그인 경우에는 다음을 수행해야 합니다. 왼쪽 측면 푸시에서 로그 목록 키 이름을 재설정합니다. 또한, 로그 목록에서 로그를 가져올 때 한 번에 모두 가져오지 마세요. 이로 인해 쉽게 Redis 차단이 발생할 수 있습니다. 매번 특정 숫자(예: 50)를 가져와서 반복해서 꺼냅니다.

핫뉴스 ID 저장

여기서 코드는 올리지 않고 주로 아이디어에 대해 이야기하겠습니다. 오늘의 가장 더운 날, 가장 더운 주, 1월의 가장 더운 날을 포함하는 메뉴 기능을 갖춘 시스템을 만들곤 했습니다. 당시 저희 웹사이트는 트래픽이 꽤 많았는데, 며칠 만에 웹사이트가 다운되었습니다. 그 이유는 mysql의 느린 쿼리 문제 때문이다. 이 SQL에는 그룹화, COUNT(), 조건부 판단 등이 포함되어 있기 때문입니다.

우리의 솔루션에 대해 말씀드리겠습니다. mysql 저장 프로시저를 작성하고 정기적으로 저장 프로시저를 호출하세요. 이 저장 프로시저의 기능은 오늘, 이번 주, 1월에 가장 인기 있는 기사를 필터링하고 각각 100개의 기사 ID를 가져와 해당 기사 ID를 Redis 대기열에 저장하는 것입니다. 가장 인기 있는 기사의 경우 상위 100개 기사만 표시됩니다. 이러한 방식으로 우리 시스템에는 느린 쿼리가 발생하지 않습니다.

위 내용은 Redis는 로그와 인기 기사를 저장합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.