노드의 비동기 메커니즘은 "이벤트"를 기반으로 합니다. 모든 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는 감지할 수 있는 활성 이벤트 리스너가 있는지 지속적으로 확인하고 이벤트 리스너가 감지되지 않을 때까지 이벤트 루프를 종료하지 않으며 프로그램이 종료됩니다.
노드 관련 지식을 더 보려면 nodejs 튜토리얼을 방문하세요!
위 내용은 노드 기반의 비동기 메커니즘은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!