조회수 기능 제거후 아래 코드로 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%까지 줄였습니다. 조회수 말고도 다른것들도 튜닝을 하면서요.. 다들 화이팅하세요.
게시글 목록
| 번호 | 제목 |
|---|---|
| 24149 | |
| 24140 | |
| 24133 | |
| 24125 | |
| 24119 | |
| 24109 | |
| 24105 | |
| 24101 | |
| 24093 | |
| 24089 | |
| 24077 | |
| 24074 | |
| 24071 | |
| 24070 | |
| 24067 | |
| 24056 | |
| 24050 | |
| 24046 | |
| 24043 | |
| 24040 | |
| 24037 | |
| 24036 | |
| 24035 | |
| 24034 | |
| 24021 | |
| 24017 | |
| 24005 | |
| 24002 | |
| 23990 | |
| 23980 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기