노드의 비동기 메커니즘은 "이벤트"를 기반으로 합니다. 모든 I/O, 네트워크 통신 및 데이터베이스 쿼리는 비차단 방식으로 실행되고 반환된 결과는 이벤트 루프에 의해 처리됩니다. 노드는 동시에 하나의 이벤트만 처리하며, 완료 후 후속 이벤트를 확인하기 위해 즉시 이벤트 루프에 진입합니다. 이러한 방식으로 CPU와 메모리는 동시에 한 가지 작업을 처리하는 데 집중하는 동시에 시간이 많이 걸리는 I/O 및 기타 작업을 병렬로 실행하도록 할 수 있습니다.

이 튜토리얼의 운영 환경: Windows 7 시스템, nodejs 버전 16, DELL G3 컴퓨터.
NodeJS는 단일 스레드입니다. 단일 스레드는
단순하고
성능이 뛰어나며 잦은 스레드 전환 오버헤드와
작은 리소스 사용을 방지합니다. 스레드 로드가 많은 경우에도 메모리 사용량이 매우 낮습니다
. -안전함, 잠금 없음, 잠금 해제 및 교착 상태와 같은 높은 동시성 문제를 해결하는 방법은 무엇입니까
?
Node는 높은 동시성 문제를 해결하기 위해 비동기 IO 및 이벤트 기반(콜백 함수)을 사용합니다.
일반적으로 동시성이 높은 솔루션은 멀티 스레딩 모델을 제공하여 각 비즈니스 로직에 대한 스레드를 제공하고 시스템 스레드 전환을 통해 동기 I/O 호출의 시간 오버헤드를 보완합니다. Apache와 마찬가지로 요청당 하나의 스레드가 있습니다.
NodeJS는 단일 스레드 모델을 사용하고 모든 I/O에 대해 비동기 요청 방법을 사용하여 빈번한 컨텍스트 전환을 방지합니다. NodeJS가 실행될 때 이벤트 큐를 유지하고 다음 이벤트가 도착할 때까지 기다립니다. , 각 비동기 I/O 요청은 완료 후 실행을 위해 이벤트 큐로 푸시됩니다.
NodeJS의 비동기 메커니즘은 이벤트 기반입니다. 모든 I/O, 네트워크 통신 및 데이터베이스 쿼리는 비차단 방식으로 실행되며 반환된 결과는 이벤트 루프에 의해 처리됩니다 . 그림과 같이:

Node.js 프로세스는 한 번에 하나의 이벤트만 처리하며, 완료 후 즉시 이벤트 루프에 들어가 후속 이벤트를 확인합니다. 이것의 장점은 CPU와 메모리가 동시에 한 가지 작업을 처리하는 데 집중하는 동시에 시간이 많이 걸리는 I/O 및 기타 작업을 병렬로 실행할 수 있다는 것입니다. 저속 연결 공격의 경우 Node.js는 이벤트 큐에 요청만 추가하고 운영 체제의 응답을 기다립니다. 따라서 멀티스레딩 오버헤드가 없으므로 웹 애플리케이션의 견고성을 크게 향상시키고 악의적인 공격을 예방할 수 있습니다.
이벤트 루프 메커니즘
소위 이벤트 루프는 NodeJS가 이벤트 메커니즘을 사용하여 모든 비동기 작업을 해결한다는 것을 의미합니다. 이벤트 큐를 감지하기 위해 지속적으로 루프하는 스레드가 있습니다.
NodeJS의 모든 로직은 이벤트 콜백 함수이므로 NodeJS는 항상 이벤트 루프에 있고 프로그램 항목은 이벤트 루프의 첫 번째 이벤트에 대한 콜백 함수입니다. 이벤트 콜백 함수는 I/O 요청을 발행하거나 이벤트를 직접 발생시키고 실행 후 이벤트 루프로 돌아갈 수 있습니다. 이벤트 루프는 프로그램이 끝날 때까지 이벤트 큐에서 처리되지 않은 이벤트를 확인합니다. NodeJS의 이벤트 루프는 개발자에게 보이지 않으며 libev 라이브러리에 의해 구현됩니다. libev는 감지할 수 있는 활성 이벤트 리스너가 있는지 지속적으로 확인하고 이벤트 리스너가 감지되지 않을 때까지 이벤트 루프를 종료하지 않으며 프로그램이 종료됩니다.
