await 상황일때
await 상황일때, 중간중간에 node가 다른 일을 할 수 있다는 것의 의미에 대해 질문드립니다.
예를 들어
await User.findOne({...});
...
비즈니스 로직
...
위와 같이 코드가 구현되있으면 findOne method가 수행되는 동안에는 밑의 비즈니스 로직들이 수행되지 않기 때문에 결국 이 순간에는 cpu가 놀고 있는것이라고 생각하는데 중간중간에 node가 다른 일을 할 수 있다는 것의 의미가 무엇인가요?
다른 언어에 비해 비동기 방식이 효율적이라는 점이 위와 같은 상황에서 어떤 장점으로 효율적이 되는지도 여쭤보고 싶습니다
감사합니다!!
답변 1
0
Dev님 안녕하세요 :)
비동기 프로그래밍이 처음에 이해하기 정말 힘든 개념인데 질문 해주셔서 감사합니다 ㅎㅎ
밀씀하신 이 부분이 하나의 API호출이라고 생각해볼게요.
await User.findOne({...});
...
비즈니스 로직
...
이 API 안에 들어간 코드를 보면 크게 2가지로 나눌 수 있어요.
1. 외부를 호출하는(데이터베이스 호출하는) 작업이 있고
2. Dev님 작성하신 비즈니스 로직(Javascript 코드)가 있어요.
Node.js 입장에서 봤을 때 이 두가지의 차이점은 이래요:
1. 외부 호출: Node.js에서 작업하는게 사실상 거의 없어요. 호출만 하면 되니깐요.
2. 비즈니스 로직: Javascript코드는 Node.js가 실제로 직접 연산을 하는 부분이에요.
그러면 각각 소요시간은 어떨까요?
일반적으로 외부 호출이 비즈니스 로직보다 수십 수백배 더 오래 걸려요. 비즈니스 로직 실행시간은 사실상 무시할 수 있는거죠. 외부 호출이 엄청 오래 걸리는데(보통 네트워크 데이터 이동 시간) 동기적으로 짜게 되면 이 때 실제로 서버 자원이 놀게 되요. 가만히 앉아서 기다리는거죠.
비동기의 장점은 이 노는 시간에 또 다른 API호출을 접수하는거에요. 이 API호출이 거의 동시에 2번 들어왔다고 생각해볼게요. 첫번째 호출에서 await User.findOne()을 하고 대기하고 있을 때 두번째 호출도 접수해서 await User.findOne({})을 또 해주는거에요. 첫번째 호출은 아직 끝나지도 않았는데 말이죠. 두 호출 중 먼저 디비에서 결과가 넘어오면 해당 호출의 비즈니스 로직을 실행하구요.
한 호출이 보통 200ms걸린다고 소요하면 비동기로 짰을 때 둘다 합쳐서 200ms근처로 응답이 와요.
비동기가 아니라면 첫번째 호출이 끝나고 다음 호출을 작업하기 때문에 첫번째는 200ms만엥 응답이 오고 두번째 호출은 400ms후에 응답이 오게 되죠.
참고로 비즈니스 로직 자체는 병렬로 동시에 처리가 되지 않아요. 다만 이 부분에서 소요되는 시간이 외부 호출에 비해 너무나도 작기 때문에 체감상으로는 동시에 처리되는거에요.
option usecreateindex is not supported 오류 나면은
0
146
1
Schemaless 특성을 재생시 검은화면이 나와요
0
240
1
user 내장 시 ref 필드 필요성
0
239
1
await 관련해서 질문드릴게 있습니다!!
0
292
2
섹션6의 3번째 강의 faker파일이 어디있나요?
0
308
1
$elemMatch 질문이 있습니다.
0
245
1
DB 업데이트에 실패했을 상황에서 대처는 어떻게 할 수 있나요.
2
766
2
블로그에 user 데이터를 추가하는 방법에 대해서
0
237
1
blog 데이터 생성시 user 관련 오류
0
351
1
age 예외 처리를 별도로 하신 이유가 궁금합니다.
2
301
2
delete 메소드가 많은 이유가 궁금합니다.
0
181
1
unique validation 처리
0
296
1
updateMany에서 user._id를 못찾는 상황
1
396
1
find() 가 리턴하는 instance member
1
431
3
몽고 db를 백업방법을 부탁합니다.
0
603
1
인덱스 생성시점
0
712
1
$pull 문법에 대한 질문
0
359
1
comment의 id가 생성되는 시점
1
301
1
리팩토링 강의에서 라우터 리팩토링 전개연산자(...)
1
315
1
session.abortTransaction()에 대한 실제 예시 문의
0
287
1
섹션9 Computed Fields 강의에서, 다음 강의 가기 전 빠진부분
-1
407
1
faker 패키지 취약성 이슈
1
485
1
라우터 리팩토링
0
341
1
섹션4 진행중, mongoose 질문
0
309
1





