프로그래밍/서버, DBMS

[Node.js] Jade(pug) 템플릿 엔진 속도 문제

포도알77 2019. 3. 4. 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 컴파일 타임이었다.)





페이스북으로 공유카카오톡으로 공유카카오스토리로 공유트위터로 공유URL 복사