조회수·댓글수 실시간 업데이트 대신 지연 카운트 적용

· 3개월 전 · 821 · 3

조회수(wr_hit), 댓글 수(wr_comment)는 페이지가 열릴 때마다 증가하는데, 이 값들을 매 요청마다 즉시 DB에 업데이트하면 서버 부하가 매우 큼. 특히 방문자가 많은 게시판일수록 병목이 발생함.
이를 해결하는 방법이 Lazy Count(지연 업데이트) 방식임. 즉, 조회수 증가를 즉시 DB 반영하지 않고 세션·캐시에 모았다가 일정 주기마다 일괄 반영하는 방법.

 

1) 조회수 증가를 APCu 캐시에 쌓기 (view.php 수정)

$post_id = $wr_id;
$cache_key = "hit_{$post_id}";

// 1회만 증가하도록 세션 체크
if(!isset($_SESSION["hit_{$post_id}"])) {
    $_SESSION["hit_{$post_id}"] = true;

    // APCu에 누적 저장
    if(function_exists('apcu_inc')) {
        apcu_inc($cache_key, 1);
    }
}
 

2) 크론에서 일정 간격으로 DB에 반영 (hit_flush.php)

include_once('./_common.php');

$keys = new APCUIterator('/^hit_/');
foreach($keys as $key => $val) {
    $wr_id = str_replace('hit_', '', $key);
    $hit = apcu_fetch($key);

    // DB 반영
    sql_query("UPDATE g5_write SET wr_hit = wr_hit + '{$hit}' WHERE wr_id = '{$wr_id}'");

    // 캐시 삭제
    apcu_delete($key);
}


크론탭 설정 예시 (5분마다 반영)

*/5 * * * * php /home/site/public_html/hit_flush.php
 

효과

고트래픽 게시판에서 DB write 횟수를 80~95% 감소

트래픽 폭주 상황에서도 사이트 안정성 향상

캐시가 없는 환경에서는 파일 기반으로도 구현 가능

|

댓글 3개

감사합니다 ^^

좋은 정보입니다.

감사합니다 

댓글을 작성하시려면 로그인이 필요합니다.

그누보드5 팁자료실

+
제목 글쓴이 날짜 조회
2개월 전 조회 1,173
2개월 전 조회 1,077
3개월 전 조회 1,120
3개월 전 조회 1,222
3개월 전 조회 1,066
3개월 전 조회 1,092
3개월 전 조회 1,228
3개월 전 조회 1,056
3개월 전 조회 1,213
3개월 전 조회 1,045
3개월 전 조회 1,065
3개월 전 조회 996
3개월 전 조회 939
3개월 전 조회 938
3개월 전 조회 822
4개월 전 조회 892
4개월 전 조회 910
4개월 전 조회 765
4개월 전 조회 926
4개월 전 조회 752
4개월 전 조회 909
4개월 전 조회 829
4개월 전 조회 1,028
4개월 전 조회 810
4개월 전 조회 839
4개월 전 조회 768
4개월 전 조회 1,024
4개월 전 조회 700
4개월 전 조회 715
4개월 전 조회 770