메뉴 건너뛰기

프로그램언어

조회 수 284 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

웹에서 가끔 실시간으로 어떤 자료들을 보여주는 페이지를 만들때가 있다.
이럴경우에는 보통 해당 페이지를 몇초에 한번 reload되도록 해놓는 방식을 사용 한다.

그런데, 이런 자료는 db에서 뽑아오는것이 보통이고, 그렇게 되면 여러사람이 사용할 경우 엄청난 db접속에 과부하가 걸리기 마련이다.

이럴경우에는 db에 뽑아온 자료를 특정 파일로 저장하고 그 자료를 불러오는 방식을 사용하면 이런 과부하를 줄일수 있다.
조금 구체적인 예는 아래와 같다.

일단 3초에 한번씩 페이지가 reload 되는 페이지를 만들었다고 하면,
해당 페이지에서는 다음과 같은 알고리즘으로 자료를 가져와 보여준다.

1. db에서 뽑아와 저장한 자료파일이 3초 이전에 만들어진 것인지를 체크 한다.
2. 해당 파일이 3초 이전에 만들어진 파일이면 해당 파일을 읽어온다.
3. 해당 파일이 3초 이전에 만들어진 파일이 아니면, 새롭게 db에 접속하여 해당 파일을 만든 뒤에 해당 파일을 읽어온다.

php소스로 대략적으로 나타내면 아래와 같다.

if( time() - filemtime($file_path) >= 3 ) db_write(); //DB에서 자료를 읽어와서 파일에 저장하는 함수
 
$fp = fopen( $file_path, "r" );
while (!feof($fp)) $file_arr []= fgets($fp);
fclose($fp);  

기본적으로는 파일을 읽지만, 읽기전에 해당 파일의 생성 시간을 체크한뒤에 새로 작성하느냐 마느냐가 있으면 될 뿐이다.

이방법이라면 여러명이 reload 되는 페이지를 사용한다고 하여도, db접속은 3초에 한번씩밖에 일어나지 않게 된다.


List of Articles
번호 제목 날짜 조회 수
80 사진이 회전되서 올라갈 경우 2020.05.25 775
79 상수, 마법상수, 모든 상수 보기 2021.03.26 236
78 새창열 때 HTTP_REFERER 값넘기는 꽁수 2019.01.08 1454
77 생성된 파일생성날짜 업데이트 만들기 / filemtime 2019.01.16 1373
76 서브도메인 세션 공유 2021.03.26 585
75 세션 시작 / 세션 데이터 추가 / 세션 데이터 삭제 / 세션 종료하기 2017.03.07 19102
74 시간관련함수 2016.12.23 17328
73 알파벳 순서대로 출력하기 ord(), chr() 2021.03.26 584
72 애니메이션 gif 와 일반 gif 구분 하기 2019.01.16 1316
71 어떤 스마트폰으로 접속했는지 알아내는 소스 , (안드로이드 아이폰 ) 2014.03.26 17716
70 엑셀(*.xls) 화일을 PHP에서 읽기 2017.03.06 17476
69 엔터의 표현 2014.02.27 19535
68 오늘 날짜 구하기 2019.01.08 1323
67 오류 메시지 출력(alert) 및 페이지 이동(refresh) 관련 2017.03.06 18568
66 웹서버조회 소스 2018.07.24 4543
65 웹에서 Excel 로 출력하기 2014.03.26 20356
64 웹페이지 파싱 2023.01.12 226
63 웹페이지 프린트 하기 html 수준 2014.03.26 19805
62 유용한 함수 모음 2014.02.27 21422
61 이미지 땡겨와서 출력하기 2018.09.28 5288
Board Pagination Prev 1 ... 8 9 10 11 12 13 14 15 16 17 Next
/ 17

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved