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

조회수 배치로 SQL 부하 줄이

· 6개월 전 · 629 · 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개월 전

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

감사합니다.

게시글 목록

번호 제목
24318
24317
24315
24309
24294
24293
24277
24262
24260
24253
24251
24236
24233
24228
24226
24221
24214
24203
24201
24199
24196
24195
24194
24192
24191
24187
24185
24183
24172
24168