inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

탄탄한 백엔드 NestJS, 기초부터 심화까지

Nest Middleware

res.on('finish')

594

이동현

작성한 질문수 2

0

안녕하세요 강의 잘 듣고 있습니다.

res.on('finish', cb); 이벤트를 걸어뒀다고 가정하고

 

만약 어떤 request에 의한 비즈니스 로직 수행 중

적당한 예외처리가 되지 못해서 서버가 죽어버리는 로직을 거쳐 res를 쏘는 부분까지 도달하지 못했다면

해당 cb함수는 실행되지 않을거라고 생각했는데 맞을까요?

(이렇게 되면.. 어떤 요청에 의해 프로그램이 죽었는지 알기 어려울 것 같다는 생각이 문득 들어서 질문드립니다)

node.js mongodb express nestjs ssr

답변 1

-1

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴이에요.

res.on('finish', cb) 코드에서 finish 이벤트는 모든 응답이 완료되었을 때 발생하는 이벤트입니다. 즉, 클라이언트에게 응답을 보내기 직전에 호출됩니다.

만약 어떤 request에 의한 비즈니스 로직 수행 중에 예외처리를 하지 못하고 서버가 비정상적으로 종료되었다면 해당 코드까지 도달하지 못하므로 cb 함수가 실행되지 않습니다. 따라서 클라이언트에게 응답 전에 어떤 요청으로 인해 서버가 종료되었는지 알기 어려울 수 있습니다.

이런 경우에는 서버의 로그를 확인하거나 예외 처리를 추가하여 어떤 요청이 문제를 일으켰는지 파악할 수 있습니다. 예를 들어, 에러 처리 미들웨어를 사용하여 예외가 발생했을 때 로그를 남길 수 있습니다. 이를 통해 어떤 요청이 문제를 일으켰는지 파악할 수 있습니다.

요약하면, res.on('finish', cb) 이벤트는 클라이언트에게 응답을 보내기 직전에 호출되지만, 예외처리가 되지 못하고 서버가 종료되는 경우 해당 코드까지 도달하지 못하며, 어떤 요청이 문제를 일으켰는지 파악하기 어려울 수 있습니다.

더 궁금한 점이 있으면 언제든지 물어보세요!

프로젝트 환경 세팅할 때 최신 노드 버젼을 사용하시는 분들은 참고하셔도 좋을 것 같아요~

2

81

1

DTO에 대한 질문

1

88

2

백엔드 MVC에서 View의 역할은 무엇인가요?

1

95

2

추가 업데이트 관련 건

0

92

2

nest js 버전문제

0

81

2

mongdb 스키마 공식 문서와 형태가 다른 이유 궁금합니다.

0

103

1

라인 끝에 에러 표시(eslint) 때문에 구글 찾아 보니.

0

76

1

전체 고양이 조회 라우터 중 error.message 오류

0

70

1

캡슐화 추가 설명 중 단일책임원칙 관련 질문

0

106

0

TypeORM과 mysql을 사용하시는 분들

4

142

1

42강 고양이끼리 소통 댓글 구현 중 Schema hasn't been registered for model 'comments' 에러 해결

0

82

1

채팅 이슈

0

134

1

모듈이 더 이상 지원하지 않는답니다

0

207

1

오류가 있습니다

0

106

1

import 에서 오류가 납니다

0

128

1

이런 오류가 나옵니다

0

101

1

에러가 발생합니다

0

110

1

프론트 에러 뜨는데 수정 안해주시나요

0

159

1

emit() broadcast.emit() 질문있습니다

0

103

1

서버연결이 안됩니다.

1

403

1

[PM2][ERROR] Command not found

0

521

1

S3에 업로드까지는 성공했는데 사진이 나오지 않습니다.

0

248

1

error_code : Property 'user' does not exist on type 'Request<ParamsDictionary, any, any, ParsedQs, Record<string, any>>'.ts(2339)

0

603

1

jwt를 따로 연습하고 있는데 env를 못읽는 것 같습니다.

0

324

2