최근 게시판 속도 빠르게 하는 방법입니다.
홈페이지에 제로보드 게시판을 이용하여 php 프로그램을 많이 하십니다.
특히 게시물이 많아질 수록 최근 게시물을 로드하는데 시간이 오래 걸림을 많이 느끼시게 될 것입니다.
그 문제를 해결하기 위해 여러가지로 알아 보았더니 원인은 바로 select 문에서 사용하는 order by 에 있었습니다.
예) select * from zetyx_board_free where is_secret=0 and father=0 order by no desc limit 10
order by 에 의해서 게시물이 정렬하는데 걸리는 시간은 n^2 (n 의 제곱) 에 비례합니다.
즉, 게시물이 10 개일 경우 100 에 해당하는 시간이 걸린다면, 게시물이 1000개인 경우 1,000,000 에 해당하는 시간이 걸린다는 것이죠.
실제로 최근 게시물 번호 ( no 필드) 가 4000 번인 게시물의 최근 리스트를 구해오는데 10초넘게 걸린 적도 있었습니다. (한번 구한 다음에는 DB 에 캐시가 저장되어 빠르게 구하지만...)
이런 문제를 해결하기 위해서 가장 최근의 게시물 몇개를 가져와서 그 것에 대해서 order by 를 적용하는 방법으로 속도를 향상 시킬 수 있습니다.
아래의 내용을 적용한 뒤에는 엄청난 효과를 보았습니다. 거의 누르자마자 화면이 뜰 정도의 속도 향상을 가져왔습니다.
제로보드 게시판을 사용하신다면 꼭 적용하셔서 홈페이지 처리속도도 향상시키시고, 서버 부하도 줄여 줍시다.
--------------------------------------------------------------------
outlogin.php 의 print_bbs 함수에 파란 색으로 표시된 부분을 삽입하시면 됩니다.
function print_bbs(...)
...
if($setup[use_alllist]) $target = "zboard.php?id=".$id;
else $target = "view.php?id=".$id;
$result = mysql_query("select * from $t_board"."_$id where is_secret=0 and father=0 order by no desc limit $num", $connect) or die(mysql_error());
----------------------------------------------------------------------
function print_bbs(...)
...
if($setup[use_alllist]) $target = "zboard.php?id=".$id;
else $target = "view.php?id=".$id;
// speed up by hankawi
$tmp = mysql_fetch_array(mysql_query("select max(no) from $t_board"."_$id"));
$max_no = $tmp[0];
if ($max_no > 500) { // 게시물 개수가 500개 이상일때만
$mylimit = $max_no - 100; // 최종 100개를 대상으로
$speedup = "no>$mylimit and";
} else {
$speedup = "";
}
$result = mysql_query("select * from $t_board"."_$id where ".$speedup." is_secret=0 and father=0 order by no desc limit $num", $connect) or die(mysql_error());
//
최병덕
이 부분은 print_bbs 말고도 다른 부분에도 적용이 가능 할까요?
즉, print_survey 또는 print_gallery 에서도 적용이 가능 하도록 수정이 될까요? 2004-12-18
12:02:43
에지
최병덕// 똑같이 수정하시면 될겁니다-ㅅ-;; (아마도... 퍽-) 2004-12-18
12:33:33
KangMin
참 매력적인 팁이네요.. 감사합니다. 2004-12-18
14:02:41
김종환
$result = mysql_query("select * from $t_board"."_$id order by headnum asc, arrangenum asc limit $num", $connect) or die(mysql_error());
인 경우엔 ".$speedup." 부분을 어디에 넣으면 되는지 알려주세요~^^ 2004-12-18
14:08:49
김훈
You have an error in your SQL syntax near '=0 order by no desc limit 8' at line 1
저는 위의 에러 메시지만 출력되는 군요. .$speedup. 이부분을 빼면 제대로 나오지만 그러면 아무 소용이 없잖아요? 2004-12-18
17:46:11
김훈
아이고...자문 자답입니다.
띄어쓰기가 아주 중요하군요...
"_$id where△".$speedup."△is_ where 와 is 사이에 ".$speedup." 을 넣을때 꼭 한칸씩 띄워주어야 돼네요. 저같이 실수하시는 분이 있을까봐 우문을 남깁니다. 2004-12-18
17:49:26
방병현
김종환 // 님의 경우 where 가 없으니 where 를 추가하셔서 넣으셔야 겠군요.
select * from $t_board"."_$id order by headnum asc ...
==>
select * from $t_board"."_$id where ".$speedup." order by headnum asc ...
그리고, and 뒤에 아무것도 없게 되니
$speedup = "no>$mylimit and";
==>
$speedup = "no>$mylimit ";
이 부분에서도 and 를 빼고 하셔야 겠군요. 2004-12-19
22:25:30
방병현
최병덕 // order by 로 쿼리를 하는 모든 select 에 대해서 적용하면 효과가 있습니다. 2004-12-19
22:31:33
김종환
설명 감사합니다~^^ 제가 해 보니 에러가....
번거로우시겠지만, 복사해서 붙여버리게 한줄로 요약을 부탁드려도 될까요?
'SQL 구문에 오류가 있습니다.' 에러 같읍니다. ('order by headnum asc, arrangenum asc limit 2' 명령어 라인 1) 2004-12-20
00:00:13
무삶이
음..좋군요.
홈피 메인 뜨는 속도가 3초 정도 되는 것 같아서..이 팁을 응용해 보았는데..
1초 정도는 단축된 거 같군요.
여러가지 최근게시물을(그것도 웹진형태로...) 만들어 놓고서 속도 때문에
플래시도 압축해보고 소스수정도 해보고,,,여러가지 해보았으나..
역시 최근게시물의 트래픽요인이라고 생각했는데...
이 팁으로 어느 정도 해결이 되어 만족스럽습니다.
추천 한방 꾹! 2004-12-20
15:00:13
드림퀘스트
희박한 경우이겠지만 쓰고 지우는 일이 잦은 게시판에서는 no 필드의 구멍때문에 원하는 갯수대로 가져오지 못할수도 있고 100개씩 가져오는것도 낭비일 수도 있겠습니다.
그래서 정확한 갯수대로 가져오려면 no 필드 보다는 headnum이 더 정확할것 같습니다.
headnum으로 가져오려면 아래와 같이 하시면 됩니다.
(테스트는 해보지 않았습니다.)
$tmp = mysql_fetch_array(mysql_query("select min(headnum) from $t_board"."_$id"));
$mylimit = $tmp[0] + $num; // 가져오기로한 게시물 갯수만큼만
$speedup = "headnum<$mylimit and";
$result = mysql_query("select * from $t_board"."_$id where ".$speedup." is_secret=0 and father=0 order by no desc limit $num", $connect) or die(mysql_error()); 2004-12-20
20:37:23
오혜성
비밀글하고, 리플글 추출이 안되던데... 어떻게 해야 하나요? 2004-12-20
22:24:49
teslaMINT
' is_secret=0 and father=0' 를 지우세요. 2004-12-21
01:00:49
오혜성
is_secret=0 and father=0 이거 지워도 안되서 질문한건뎅...ㅠㅠ
$speedup = "no>$mylimit "; 위 라인 지우구 이렇게 해두.. 마찬가지던데요. 2004-12-21
02:34:53
채정현
드림퀘스트님, 그렇게 하면, 공지사항이 있는 게시물의 경우 공지사항만 추출되는 사태가...
ㅡ.ㅡ;; 2004-12-21
19:15:02
방병현
드림퀘스트님/
저도 사실 그런 부분이 고민이었습니다. 사실 100개 까지 리스트를 가져올 필요는 없지요. 더 작게 주셔도 상관이 없습니다.
하지만 중간에 삭제가 많이 일어나는 경우 구멍이 생기기 때문에 무난한 숫자로 그냥 100 으로 준 것입니다.
좋은 아이디어 감사합니다. 하지만 중간에 구멍이 생기는 문제는 headnum 으로 해도 똑같이 발생하는 문제이군요. 2004-12-22
23:45:37
teslaMINT
$speedup..... 은 지우면 안되는데요. 2004-12-23
09:44:07
드림퀘스트
headnum은 중복되는 번호가 생기고 no보다는 덜하지만 간간히 구멍이 있네요.
제가 위에 코멘트에서 언급한 headnum은 사용하시면 안되겠습니다. ^^ 2005-01-05
01:54:18
제로맨
헛.... 진짜 빨라져따......*^^* (감사) 2005-08-27
18:23:43
빛소리
상쾌해집니다....시원해지고 .... 윤활류 발라진 기계처럼. 감사.... 2005-09-03
10:33:02
별의카비
안되는데요 -_-;