조회수 배치로 SQL 부하 줄이 > 그누보드5 팁자료실

그누보드5 팁자료실

조회수 배치로 SQL 부하 줄이 정보

조회수 배치로 SQL 부하 줄이

본문

조회수 기능 제거후 아래 코드로 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%까지 줄였습니다. 조회수 말고도 다른것들도 튜닝을 하면서요.. 다들 화이팅하세요.

추천
4

댓글 2개

전체 2,629 |RSS
그누보드5 팁자료실 내용 검색

회원로그인

(주)에스아이알소프트 / 대표:홍석명 / (06211) 서울특별시 강남구 역삼동 707-34 한신인터밸리24 서관 1404호 / E-Mail: admin@sir.kr
사업자등록번호: 217-81-36347 / 통신판매업신고번호:2014-서울강남-02098호 / 개인정보보호책임자:김민섭(minsup@sir.kr)
© SIRSOFT