속도를 위해 데이터를 접속자 메모리에

주로 관리자만 게시물을 올리고 접속자는 열람만 하는 데이터 베이스의 경우,
그리고 대부분의 사용자가 요구하는 데이터가 1M 미만인 경우,
접속자가 접속하는순간 데이터 베이스의 내용을 그대로 접속자의 메모리에 올려 버려서 그다음은 접속자가 계속 검색을 하는 내용이 모두 서버와의 교신 없이 이루어 지게 하면 서버의 부하를 비약적으로 줄일 수 있습니다.
특히 연구 관련 사이트에서 한번 접속하면 한두시간씩 검색을 하는 경우 유용하지요.
그럴수 밖에 없는 것이 데이터 베이스 쿼리도 한번, 서버에서 자료를 주는 것도 접속한 순간 한번에 끝나는 것으로써 서버에서는 세션 등의 관리조차 필요없어 지니까요.

이것은 프레임을 사용해서 합니다.

*** index.html ***

<html>
<head>
<title>Welcome</title>
</head>
<frameset rows="100%,0%" frameborder="NO" border="0" framespacing="0">
<frame name="main" src="home.html">
<frame name="process" scrolling="NO" noresize src="initializer.html">
</frameset>
</html>

여기서 세개의 페이지가 로딩 되는데요.
top 프레임은 html자체로는 아무 내용도 없는 것 같지만 process프레임에서 돌아가는 javascript가 모든 데이터를 테이블 통째로 top프레임의 메모리에 올려놓습니다.
main프레임에서는 이 데이터를 이용해서 고객에게 검색 결과를 보여주게 되며 서버와는 고객이 refresh버튼을 누르지 않는 이상 교신하지 않습니다.
"검색" 버튼을 누른다고 해도 페이지를 새로 로드해서 보여주는 것이 아니라 javascript 함수로 페이지 자체를 새로 build해서 document.writeI()으로 써주기 때문에 고객의 입장에서는 페이지가 새로 로드된 것 같지만 실상은 서버와 아무런 통신이 없지요.

그러나 프로세스 프레임을 고객이 굳이 보게되면 (아무리 보이지 않는 프레임이라 해도 볼수 있으니까) 자료 테이블을 통째로 보고 황당해 할테니까 고객의 안심을 위해서 약간의 팁이 필요한데 아래 주석 달린 소스를 읽어보세요.
물론 이것은 얼마든지 브레이크 하고 열람할 수 있기 때문에 절대로 절대로 보안상의 이유로는 쓸수 없으며 단지 고객을 편안하게 해주기 위해서 하는 것 뿐입니다.

*** initializer.html ***
//데이터 구조에 대한 PHP클라스 정의가 여기 들어 있습니다. 디비를 직접 엑세스 하는 것은 이 페이지 뿐이니 다른 페이지에서는 사용하지 않습니다. (다른 페이지에서는 PHP자체를 사용하지 않습니다)
<?require "dbclass.inc";?>
<html>
<head>
<title>Data Loader</title>
//데이터 구조에 대한 Javascript class 정의가 이 파일에 들어 있습니다. 데이터를 사용하기 위해서는 메인 프레임의 페이지에서도 물론 이 스크립트 파일을 사용해야지요.
<script src='include/jslibrary.js'></script>
<script>
<?
$s = "
var w = window;
var t = window.top;
var d = window.document;
//모든 정보는 탑 프레임의 메모리에 상주하는 windows.top.db 에 저장됩니다.
t.db = new Object();
";

$preload = array();

$preload["mydata"] = "SELECT * FROM mydata ORDER BY reg_date;";
$preload["mydata2"] = "SELECT * FROM anotherdata ORDER BY subject;";

// 모든 데이터는 이 프레임이 아니라 Top 프레임의 메모리에 저장되기 때문에 이 프레임이 사라져도 상관 없다.
foreach($preload as $key=>$val) {
$q = sql_q($val);
$class_name = "C".$key;
$s .= 't.db.'.$key." = new Array();n";
while ($r = new $class_name(sql_r($q))) {
$s .= 't.db.'.$key.'[t.db.'.$key.'.length] = '.$r->clientize().";n";

}

// 탑 프레임의 Flag에 표시해서 데이터 업로드가 끝났다는 것을 표시. 메인 페이지에서 참조하고 데이터 엑세스를 시작할 수 있도록

$s .= "
t.loaded = true;
" ;

// 자바스크립트 텍스트를 뿌려주기 전에 약간 읽기 편하게(?) 만들어준다.
// 모든 코멘트 삭제, 줄바꿈, 탭, 필요없는 스페이스 삭제.
$search = array("'([rn])s+'i", "'(//.*n|/*/.**/|[trn])'si", "'s*=s*'i", "',s+'i", "';s+'i");
$replace = array("", "", "=", ",", ";");

// 거기다가 다시 보기좋게(?) encoding 해줌
$s = rawurlencode(preg_replace($search, $replace, $s));

// 자바스크립트에서 받은 다음에 decode해서 사용하도록 (자바스크립 1.1부터 지원)
echo "eval(unescape("$s"));";
?>

// 아무리 알아보기 힘들다고 해도 역시 않보여 주는 것이 최고!
// 페이지가 로딩되는 순간 다시 모든것을 지워버린다.
// 페이지를 다 만든다음 버퍼에서 뿌려주기 때문에 로딩이 시작된후 끝나고 지워지는데 까지 걸리는 시간은 0.01 초?
function done() {
document.write(" ");
document.close();
}

</script>
</head>
<body onload="done();">
</body>
</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 포럼 스크린리더 센스리더 개발자톡 개발자팁 퍼블리셔톡 퍼블리셔팁 기획자톡 기획자팁 프로그램강좌 퍼블리싱강좌
+
제목 글쓴이 날짜 조회
19년 전 조회 3,074
19년 전 조회 6,245
19년 전 조회 7,018
19년 전 조회 3,925
19년 전 조회 2,409
19년 전 조회 2,293
19년 전 조회 7,082
19년 전 조회 2,585
19년 전 조회 4,137
19년 전 조회 5,531
19년 전 조회 2,859
19년 전 조회 1,910
19년 전 조회 1,759
19년 전 조회 1,708
19년 전 조회 1,984
19년 전 조회 1,990
19년 전 조회 1,981
19년 전 조회 1,899
19년 전 조회 2,700
19년 전 조회 2,515
19년 전 조회 3,655
19년 전 조회 2,784
19년 전 조회 2,757
19년 전 조회 3,600
19년 전 조회 4,810
19년 전 조회 3,155
19년 전 조회 2,999
19년 전 조회 3,536
19년 전 조회 6,467
19년 전 조회 2,381
19년 전 조회 2,185
19년 전 조회 2,145
19년 전 조회 2,201
19년 전 조회 3,375
19년 전 조회 2,449
19년 전 조회 2,126
19년 전 조회 1,831
19년 전 조회 2,277
19년 전 조회 3,549
19년 전 조회 3,414
19년 전 조회 2,115
19년 전 조회 1,679
19년 전 조회 3,359
19년 전 조회 2,234
19년 전 조회 1,809
19년 전 조회 3,036
19년 전 조회 2,163
19년 전 조회 2,031
19년 전 조회 2,006
19년 전 조회 1,966
19년 전 조회 2,396
19년 전 조회 2,822
19년 전 조회 1,970
19년 전 조회 1,713
19년 전 조회 1,719
19년 전 조회 1,674
19년 전 조회 3,406
19년 전 조회 3,095
19년 전 조회 1,845
19년 전 조회 3,600
19년 전 조회 2,022
19년 전 조회 1,667
19년 전 조회 2,139
19년 전 조회 2,285
19년 전 조회 1,841
19년 전 조회 2,528
19년 전 조회 2,172
19년 전 조회 1,783
19년 전 조회 1,971
19년 전 조회 2,232
19년 전 조회 1,996
19년 전 조회 1,781
19년 전 조회 1,843
19년 전 조회 3,336
19년 전 조회 2,189
19년 전 조회 2,053
19년 전 조회 4,546
19년 전 조회 5,174
19년 전 조회 3,347
19년 전 조회 3,077
19년 전 조회 3,684
19년 전 조회 2,221
19년 전 조회 2,580
19년 전 조회 2,881
19년 전 조회 2,946
19년 전 조회 2,547
19년 전 조회 1,814
19년 전 조회 3,599
19년 전 조회 2,172
19년 전 조회 2,571
19년 전 조회 2,639
19년 전 조회 3,071
19년 전 조회 5,395
19년 전 조회 2,673
19년 전 조회 3,512
19년 전 조회 4,447
19년 전 조회 2,708
19년 전 조회 2,640
19년 전 조회 4,239
19년 전 조회 2,935