조회수 배치로 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개
유용한 정보네요 감사합니다.

감사합니다.