블로그 이미지
포도알77
IT 방랑기

calendar

  1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30        

Notice

2019.03.04 16:03 프로그래밍/서버
요약 :
 1. Node.js에서 사용하는 Pug 템플릿 엔진 (Jade)를 이용하면 간단한 페이지도 로드되는데 굉장히 오래 걸린다.

 2. 코드를 구성하기 나름이지만, 쿼리 + Pug 컴파일 + 변수 대입 + 요청 응답4단계에서 컴파일 타임이 약 8할이상 시간이 걸린다. (응답시간 1초의 경우 약 800ms이상 소요)

 3. Pug 엔진에서 캐시가 가능하다. 



 결과 : 컴파일 시간이 0ms으로,  응답시간이 5배 이상 빨라진다.  



 var fn = pug.compileFile('파일.pug',{
  basedir:__dirname,
  cache:true
});
res.writeHead(200, {'Content-Type' : 'text/html'});
res.end(fn(varlist));


 캐시이므로, 서버 켜질때 모든 PUG가 컴파일 되는 것은 아니다.

 처음 해당 페이지로 접근하여 Pug엔진에서 캐시가 되면, 그 다음부터 컴파일하지 않고 바로 처리된다.

  단, 캐시이기 때문에 Pug를 바로 수정할 수 없다. 따라서 반드시 서버를 다시 켜야한다.     캐시 설정 이전 (설명 : 요청 전달까지  ~ 1ms, 요청 응답 대기 520ms, 다운로드까지 52ms)


 여기서 요청 응답 대기 시간중 대부분이 컴파일 시간이다. 실제 쿼리는 약 50~100ms(웹 서버와 DB서버는 원격지에 있다)



[캐싱 설정 이전]

  





[캐시 설정 이후]

 (설명 : 캐시 이전보다 요청 응답 대기 시간이 약 1/9으로 줄었다. 즉, 대부분의 시간이 Pug 컴파일 타임이었다.)





posted by 궁금한 포도알77