테스트 사이트 - 개발 중인 베타 버전입니다

조회수 배치로 SQL 부하 줄이

· 6개월 전 · 633 · 2

조회수 기능 제거후 아래 코드로 txt 파일에 조회수 넣어두기

<?php
$bo_table = $_GET['bo_table'] ?? '';
$wr_id = $_GET['wr_id'] ?? '';
if (!$bo_table || !$wr_id) exit;

// 경로 설정
$dir = __DIR__ . "/data/viewcount";
if (!is_dir($dir)) mkdir($dir, 0777, true);

$file = "$dir/{$bo_table}_{$wr_id}.txt";

// 파일에 조회수 누적
if (file_exists($file)) {
    $count = (int)file_get_contents($file);
    file_put_contents($file, $count + 1);
} else {
    file_put_contents($file, 1);
}
?>
 

 

batch_viewcount_update.php

<?php
include_once('./common.php'); // 그누보드 DB 연결을 위해 필요

$dir = __DIR__ . "/data/viewcount";
if (!is_dir($dir)) exit;

$files = glob("$dir/*.txt");

foreach ($files as $file) {
    $filename = basename($file); // e.g. notice_123.txt
    [$bo_table, $wr_id_with_ext] = explode('_', $filename);
    $wr_id = (int)str_replace('.txt', '', $wr_id_with_ext);
    $count = (int)file_get_contents($file);

    if ($count > 0 && $bo_table && $wr_id) {
        // 조회수 증가
        sql_query("UPDATE {$g5['write_prefix']}{$bo_table} SET wr_hit = wr_hit + $count WHERE wr_id = '$wr_id'");
    }

    // 파일 삭제 또는 초기화
    unlink($file);
}
 

크론탭으로 배치 파일 실행 (5분마다 실행)

*/5 * * * * /usr/bin/php /home/your_site/public_html/batch_viewcount_update.php
 

이런식으로해서 부하를 cpu사용량 300%에서 60%까지 줄였습니다. 조회수 말고도 다른것들도 튜닝을 하면서요.. 다들 화이팅하세요.

댓글 작성

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

로그인하기

댓글 2개

6개월 전

유용한 정보네요 감사합니다.

감사합니다.

게시글 목록

번호 제목
23254
23244
23241
23236
23200
23199
23179
23174
23138
23128
23125
23116
23109
23099
23092
23083
23079
23063
23050
23036
23029
23007
23003
22983
22959
22943
22939
22934
22905
22897