메뉴 건너뛰기

프로그램언어

조회 수 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. $_FILES

    Date2016.12.23 Views23847
    Read More
  2. $_SERVER 함수

    Date2016.12.23 Views23943
    Read More
  3. $_SERVER 환경변수

    Date2016.09.21 Views33237
    Read More
  4. $_SERVER변수

    Date2014.02.27 Views24446
    Read More
  5. 13자리 timestamp 생성하기

    Date2020.09.28 Views652
    Read More
  6. addslashes — 문자열을 슬래시로 인용

    Date2016.12.23 Views23083
    Read More
  7. addslashes 함수의 필요성

    Date2015.04.14 Views24250
    Read More
  8. ajax refresh 시키기(자동리플래쉬) with php

    Date2017.03.06 Views23186
    Read More
  9. Ajax로 구연한 실시간 서버시간출력

    Date2017.03.06 Views21032
    Read More
  10. AJAX로 해당 페이지에서 COOKIE 사용하기

    Date2021.03.26 Views359
    Read More
  11. AJAX를 활용하여 JSON 댓글 처리하기 (PHP)

    Date2018.07.04 Views8456
    Read More
  12. array (배열)

    Date2015.04.14 Views24904
    Read More
  13. array_key_exists 배열에서 key가 존재하는지 확인

    Date2016.12.23 Views22206
    Read More
  14. array_push 배열 끝에 하나 이상의 요소를 추가

    Date2016.12.23 Views21604
    Read More
  15. array_slice 배열의 일부를 추출

    Date2016.12.23 Views20775
    Read More
  16. base64 인코딩/디코딩 함수의 특징

    Date2018.02.09 Views13080
    Read More
  17. call_user_func 사용자가 정의한 함수를 호출하여 실행고자 할 때 사용

    Date2016.12.23 Views21305
    Read More
  18. class_exists 클래스가 정의되었는지 확인

    Date2016.12.23 Views19881
    Read More
  19. Class를 이용한 DB Connection 소스 (Oracle, MyS

    Date2014.02.27 Views30504
    Read More
  20. CodeIgniter - DB오류체크, 디버깅 여부 설정

    Date2021.03.29 Views496
    Read More
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 17 Next
/ 17

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved