메뉴 건너뛰기

프로그램언어

조회 수 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초에 한번씩밖에 일어나지 않게 된다.


  1. No Image 26Mar
    by 조쉬
    2021/03/26 Views 284 

    MYSQL DB 다중접속을 해결 하는 한 방법

  2. No Image 14Apr
    by
    2015/04/14 Views 20157 

    MySQL DB 중복여부 검사하여 없는 것만 추가

  3. No Image 26Mar
    by
    2021/03/26 Views 915 

    MYSQL DB의 모든 테이블에서 문자열 검색 하기

  4. No Image 27Feb
    by
    2014/02/27 Views 19729 

    MYSQL 업데이트 두 번 하기

  5. No Image 27Feb
    by
    2014/02/27 Views 20349 

    mysql 에러 구문 표시

  6. No Image 28Mar
    by
    2018/03/28 Views 8154 

    MySQL(MariaDB) 테이블 만들기

  7. No Image 23Dec
    by
    2016/12/23 Views 18807 

    mysql_affected_rows — 최근 MySQL 작업으로 변경된 행 개수를 얻음

  8. No Image 25Mar
    by
    2021/03/25 Views 353 

    mysql_free_result(); 관련 오류

  9. No Image 23Dec
    by
    2016/12/23 Views 18752 

    mysql_insert_id

  10. No Image 23Dec
    by
    2016/12/23 Views 18640 

    mysql_real_escape_string 이진 데이터를 입력할 경우 이 함수를 사용해야 함

  11. No Image 23Dec
    by
    2016/12/23 Views 18967 

    mysql_result — 결과 데이터를 반환

  12. No Image 24Jul
    by
    2018/07/24 Views 4798 

    MySQL테이블의 내용을 엑셀파일(xls)로 다운로드 하기

  13. No Image 23Dec
    by
    2016/12/23 Views 19774 

    parse_ini_file — Parse a configuration file

  14. No Image 26Mar
    by
    2021/03/26 Views 690 

    PEAR DB 관련 함수들

  15. No Image 25Feb
    by
    2019/02/25 Views 1558 

    PHP $_SERVER 함수

  16. No Image 21Jan
    by
    2021/01/21 Views 1141 

    PHP + 유튜브(youtube) 동영상 업로드 연동 소스

  17. No Image 12Jan
    by
    2023/01/12 Views 270 

    PHP - 공공 DATA XML 파싱(PHP 버전)

  18. PHP continue 문

  19. php date 날짜 관련 함수

  20. No Image 27Oct
    by
    2018/10/27 Views 4091 

    PHP eregi가 빠를까, strpos가 빠를까?

Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 17 Next
/ 17

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved