사이트 첫페이지 로딩 속도 개선 (캐싱처리)
첫페이지 로딩속도는 그 사이트의 운명을 좌우할 만큼 중요합니다.
왜냐면 대부분의 웹사용자는 3초를 기다리지 못하고 사이트를 떠나는게 현실이며
0.1초라도 더 빨리 첫페이지를 보여주는 것이 운영자의 사업이익과도 직결된다고 할 수 있겠습니다.
공통된 문제는 대부분의 사이트 첫페이지가 실시간으로 DB에 접속하고 DB에서 게시물을 가져온다는 것입니다.
이러다 보니 동시접속자가 많아지면 자연 로딩속도가 늘여지고 이탈현상이 발생되는 것이지요.
보여줄 메인HTML(최근 게시물 등 기타 MySQL쿼리 결과물 포함)을 미리 만들어 놓고 운영하는 방법입니다.
자세히 설명드리면
Linux에는 cron이라는 것이 있는데 이는 특정시간에 특정Job을 수행하는 시스템유틸리티 입니다.
이를 이용하여 매시간 5,15,25,35,45,55분에 10분뒤에 사용할 메인HTML을 만들고
사용자에게는 10분전에 만들어진 현재 시간대의 메인HTML을 보여주는것이지요.
예로 13:15이면 cron에 의해 main_1320.htm을 만들고 사용자는 main_1310.htm을 보여주고 main_1300.htm은 지웁니다.
이를 구현한 Full Source입니다.
1) cron의 내용
$ crontab -l [Enter]
5,15,25,35,45,55 * * * * /절대PATH/make_main.sh
$
크론과 쉘이 무었인지 잘 모르시면 Linux 참고문헌을 보세요.
2) make_main.sh의 내용
cd /절대PATH/
php < ./make_main.php
3) make_main.php의 내용
<?php
$main_path = "/절대PATH/main_";
$before = $main_path.substr(date("Hi",strtotime("-10 minute")),0,3)."0.htm";
$after = $main_path.substr(date("Hi",strtotime("+10 minute")),0,3)."0.htm";
$falg = 0;
$fi = fopen ("http://도메인/main.php", "r");
$fo = fopen ($after, "w");
while (!feof ($fi)) {
$buff = fgets($fi,4096);
if (ereg("<!-- MAIN.HTM 시작 -->",$buff)) $flag = 1; //앞부분 버림
if ($flag == 1) fputs($fo, $buff);
}
fclose ($fo);
fclose ($fi);
if (file_exists($before)) unlink($before);
?>
4) index.html의 내용
<?php
include("상단HTML");
$main_path = "/절대PATH/main_";
$current = $main_path.substr(date("Hi",strtotime("now")),0,3)."0.htm";
include($current);
include("하단HTML");
?><div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 16:57:14 JavaScript에서 이동 됨]</div>
왜냐면 대부분의 웹사용자는 3초를 기다리지 못하고 사이트를 떠나는게 현실이며
0.1초라도 더 빨리 첫페이지를 보여주는 것이 운영자의 사업이익과도 직결된다고 할 수 있겠습니다.
공통된 문제는 대부분의 사이트 첫페이지가 실시간으로 DB에 접속하고 DB에서 게시물을 가져온다는 것입니다.
이러다 보니 동시접속자가 많아지면 자연 로딩속도가 늘여지고 이탈현상이 발생되는 것이지요.
보여줄 메인HTML(최근 게시물 등 기타 MySQL쿼리 결과물 포함)을 미리 만들어 놓고 운영하는 방법입니다.
자세히 설명드리면
Linux에는 cron이라는 것이 있는데 이는 특정시간에 특정Job을 수행하는 시스템유틸리티 입니다.
이를 이용하여 매시간 5,15,25,35,45,55분에 10분뒤에 사용할 메인HTML을 만들고
사용자에게는 10분전에 만들어진 현재 시간대의 메인HTML을 보여주는것이지요.
예로 13:15이면 cron에 의해 main_1320.htm을 만들고 사용자는 main_1310.htm을 보여주고 main_1300.htm은 지웁니다.
이를 구현한 Full Source입니다.
1) cron의 내용
$ crontab -l [Enter]
5,15,25,35,45,55 * * * * /절대PATH/make_main.sh
$
크론과 쉘이 무었인지 잘 모르시면 Linux 참고문헌을 보세요.
2) make_main.sh의 내용
cd /절대PATH/
php < ./make_main.php
3) make_main.php의 내용
<?php
$main_path = "/절대PATH/main_";
$before = $main_path.substr(date("Hi",strtotime("-10 minute")),0,3)."0.htm";
$after = $main_path.substr(date("Hi",strtotime("+10 minute")),0,3)."0.htm";
$falg = 0;
$fi = fopen ("http://도메인/main.php", "r");
$fo = fopen ($after, "w");
while (!feof ($fi)) {
$buff = fgets($fi,4096);
if (ereg("<!-- MAIN.HTM 시작 -->",$buff)) $flag = 1; //앞부분 버림
if ($flag == 1) fputs($fo, $buff);
}
fclose ($fo);
fclose ($fi);
if (file_exists($before)) unlink($before);
?>
4) index.html의 내용
<?php
include("상단HTML");
$main_path = "/절대PATH/main_";
$current = $main_path.substr(date("Hi",strtotime("now")),0,3)."0.htm";
include($current);
include("하단HTML");
?><div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 16:57:14 JavaScript에서 이동 됨]</div>
|
댓글을 작성하시려면 로그인이 필요합니다.
프로그램
태그 필터 (최대 3개)
전체
개발자
소스
기타
mysql
팁자료실
javascript
php
linux
flash
정규표현식
jquery
node.js
mobile
웹서버
os
프로그램
강좌
썸네일
이미지관련
도로명주소
그누보드5
기획자
견적서
계약서
기획서
마케팅
제안서
seo
통계
서식
통계자료
퍼블리셔
html
css
반응형
웹접근성
퍼블리싱
표준화
반응형웹
홈페이지기초
부트스트랩
angularjs
포럼
스크린리더
센스리더
개발자톡
개발자팁
퍼블리셔톡
퍼블리셔팁
기획자톡
기획자팁
프로그램강좌
퍼블리싱강좌
댓글 1개