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

요약 :
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 컴파일 타임이었다.)

jcdgods

누구게?

You may also like...

답글 남기기

Translate »