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

조회수 배치로 SQL 부하 줄이

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

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

감사합니다.

게시글 목록

번호 제목
23606
23598
23585
23579
23578
23564
23550
23549
23548
23529
23510
23507
23481
23471
23453
23452
23450
23436
23428
23404
23396
23389
23380
23369
23350
23337
23317
23307
23298
23290