조회수 기능 제거후 아래 코드로 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%까지 줄였습니다. 조회수 말고도 다른것들도 튜닝을 하면서요.. 다들 화이팅하세요.
게시글 목록
| 번호 | 제목 |
|---|---|
| 23254 | |
| 23244 | |
| 23241 | |
| 23236 | |
| 23200 | |
| 23199 | |
| 23179 | |
| 23174 | |
| 23138 | |
| 23128 | |
| 23125 | |
| 23116 | |
| 23109 | |
| 23099 | |
| 23092 | |
| 23083 | |
| 23079 | |
| 23063 | |
| 23050 | |
| 23036 | |
| 23029 | |
| 23007 | |
| 23003 | |
| 22983 | |
| 22959 | |
| 22943 | |
| 22939 | |
| 22934 | |
| 22905 | |
| 22897 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기