찾다
웹 프론트엔드JS 튜토리얼Node의 높은 동시성 원칙에 대한 간략한 분석

Node의 높은 동시성 원칙에 대한 간략한 분석

Oct 18, 2022 pm 08:53 PM
nodejsnode높은 동시성

Node의 높은 동시성 원칙에 대한 간략한 분석

먼저 몇 가지 일반적인 설명을 살펴보겠습니다.

  • nodejs는 단일 스레드 + 비차단 I/O 모델입니다.
  • nodejs는 높은 동시성에 적합합니다.
  • nodejs는 I/O 집약적 애플리케이션에 적합합니다. CPU 집약적이지 않은 애플리케이션 [관련 튜토리얼 추천: nodejs 비디오 튜토리얼]

이 진술이 사실인지, 그 이유를 자세히 분석하기 전에 몇 가지 준비 작업을 합시다

처음부터 시작합시다

공통 웹 애플리케이션이 수행할 작업

  • 작업(비즈니스 로직 실행, 수학 연산, 함수 호출 등. 주요 작업은 CPU에서 수행됨)
  • I/O(예: 파일 읽기 및 쓰기, 데이터베이스 읽기 및 쓰기) , 네트워크 요청 읽기 및 쓰기 등 주요 작업은 디스크, 네트워크 카드 등과 같은 다양한 I/O 장치에서 수행됩니다.)

전형적인 기존 웹 애플리케이션 구현

  • 다중 프로세스 , 하나의 요청은 (하위) 프로세스 + 차단 I/O(예: I/O 또는 BIO 차단)를 분기합니다.
  • 멀티 스레딩, 하나의 요청은 스레드 + 차단 I/O를 생성합니다.

다중 프로세스 웹 애플리케이션 예시 의사 code

listenFd = new Socket(); // 创建监听socket
Bind(listenFd, 80); // 绑定端口
Listen(listenFd);   // 开始监听

for ( ; ; ) {
    // 接收客户端请求,通过新的socket建立连接
    connFd = Accept(listenFd);
    // fork子进程
    if ((pid = Fork()) === 0) {
        // 子进程中
        // BIO读取网络请求数据,阻塞,发生进程调度
        request = connFd.read();
        // BIO读取本地文件,阻塞,发生进程调度
        content = ReadFile('test.txt');
        // 将文件内容写入响应
        Response.write(content);
    }
}

멀티 스레드 응용 프로그램은 하나의 요청이 하나의 프로세스에 할당된다는 점을 제외하면 실제로 다중 프로세스와 유사합니다. 스레드를 할당하라는 요청이 됩니다. 스레드는 프로세스보다 가볍고 시스템 리소스를 덜 차지합니다. 컨텍스트 전환(ps: 소위 컨텍스트 전환, 약간의 설명: 단일 코어 CPU는 동시에 하나의 프로세스 또는 스레드에서만 작업을 실행할 수 있습니다. 매크로의 인터넷 병렬화에서는 각 프로세스와 스레드가 실행될 기회를 갖도록 시간 분할에 따라 여러 프로세스 또는 스레드 간에 전환해야 합니다.) 동시에 오버헤드도 더 적습니다. 개발을 용이하게 하는 스레드 간 메모리 공유

Up 기사에서는 웹 애플리케이션의 두 가지 핵심 사항을 언급했는데, 하나는 스레드 모델이고 다른 하나는 I/O 모델입니다. 그렇다면 I/O를 차단하는 것이 정확히 무엇입니까? 다른 I/O 모델에는 어떤 것이 있나요? 걱정하지 마세요. 먼저 방해가 무엇인지 살펴보겠습니다

방해가 무엇인가요? I/O 차단이란 무엇입니까?

간단히 말하면, 차단이란 함수 호출이 반환되기 전에 현재(스레드) 프로세스가 일시 중지되고 대기 상태로 진입한다는 의미입니다. 이 상태에서는 현재(스레드) 프로세스가 일시 중지되고 CPU가 스레드(스레드)를 처리하게 됩니다. ) 스레드 스케줄링. 함수는 모든 내부 작업이 완료된 후에만 호출자에게 반환됩니다

따라서 I/O 차단은 애플리케이션이 API를 통해 I/O 작업을 호출한 후 현재(스레드) 스레드가 대기 상태로 들어가고 코드가 실행된다는 의미입니다. 실행을 계속할 수 없습니다. 이때 CPU는 스레드(스레드) 스케줄링을 수행할 수 있습니다. 즉, 실행을 계속하려면 현재 스레드(스레드)가 반환됩니다.

다중 스레드 + 블로킹 I/O 모델에 어떤 문제가 있나요?

블로킹과 블로킹 I/O가 무엇인지 이해한 후, 기존 웹 애플리케이션의 다중 프로세스(스레드) + 블로킹 I/O 모델의 단점을 분석해 보겠습니다.

요청에는 들어오는(스레드) 스레드가 할당되어야 하기 때문에 이러한 시스템은 동시성이 클 때 많은 수의 들어오는(스레드) 스레드를 유지해야 하며 많은 수의 컨텍스트 전환이 필요합니다. 많은 양의 CPU, 메모리 및 기타 시스템 리소스를 지원하므로 동시 요청이 많이 들어오면 CPU 및 메모리 오버헤드가 급격히 증가하여 전체 시스템이 빠르게 중단되고 서비스를 사용할 수 없게 될 수 있습니다

nodejs 애플리케이션 구현

다음으로 nodejs 애플리케이션이 어떻게 구현되는지 살펴보겠습니다.

  • 이벤트 중심, 단일 스레드(메인 스레드)
  • 비차단 I/O 공식 웹사이트에서 볼 수 있듯이 nodejs의 두 가지 주요 기능은 단일 스레드 이벤트 중심 및 "비차단" I/O 모델입니다. 단일 스레드 + 이벤트 기반은 이해하기 더 쉽습니다. 프론트엔드 학생들은 js의 단일 스레드 및 이벤트 루프 메커니즘에 익숙해야 하므로 주로 이 "비차단 I/O"가 무엇인지 살펴보겠습니다. 먼저 nodejs 서버 애플리케이션의 공통 코드를 살펴보겠습니다.
const net = require('net');
const server = net.createServer();
const fs = require('fs');

server.listen(80);  // 监听端口
// 监听事件建立连接
server.on('connection', (socket) => {
    // 监听事件读取请求数据
    socket.on('data', (data) => {
    // 异步读取本地文件
    fs.readFile('test.txt', (err, data) => {
            // 将读取的内容写入响应
            socket.write(data);
            socket.end();
        })
    });
});

nodejs에서는 API를 통해 I/O 작업을 호출한 후 비동기 방식으로 I/O 작업을 수행할 수 있음을 알 수 있습니다. 즉시 다른 코드 로직을 계속 실행할 수 있는데 nodejs의 I/O가 "비차단"인 이유는 무엇입니까? 이 질문에 답하기 전에 몇 가지 준비 작업을 해보겠습니다. nodejs 고급 동영상 설명을 참조하세요. Enter learning

기본 읽기 작업 단계

먼저 다음 읽기 작업에 필요한 단계를 살펴보겠습니다

  • 用户程序调用I/O操作API,内部发出系统调用,进程从用户态转到内核态
  • 系统发出I/O请求,等待数据准备好(如网络I/O,等待数据从网络中到达socket;等待系统从磁盘上读取数据等)
  • 数据准备好后,复制到内核缓冲区
  • 从内核空间复制到用户空间,用户程序拿到数据

接下来我们看一下操作系统中有哪些I/O模型

几种I/O模型

阻塞式I/O

Node의 높은 동시성 원칙에 대한 간략한 분석


非阻塞式I/O

Node의 높은 동시성 원칙에 대한 간략한 분석


I/O多路复用(进程可同时监听多个I/O设备就绪)

Node의 높은 동시성 원칙에 대한 간략한 분석


信号驱动I/O

Node의 높은 동시성 원칙에 대한 간략한 분석


异步I/O

Node의 높은 동시성 원칙에 대한 간략한 분석


那么nodejs里到底使用了哪种I/O模型呢?是上图中的“非阻塞I/O”吗?别着急,先接着往下看,我们来了解下nodejs的体系结构

nodejs体系结构,线程、I/O模型分析

Node의 높은 동시성 원칙에 대한 간략한 분석

最上面一层是就是我们编写nodejs应用代码时可以使用的API库,下面一层则是用来打通nodejs和它所依赖的底层库的一个中间层,比如实现让js代码可以调用底层的c代码库。来到最下面一层,可以看到前端同学熟悉的V8,还有其他一些底层依赖。注意,这里有一个叫libuv的库,它是干什么的呢?从图中也能看出,libuv帮助nodejs实现了底层的线程池、异步I/O等功能。libuv实际上是一个跨平台的c语言库,它在windows、linux等不同平台下会调用不同的实现。我这里主要分析linux下libuv的实现,因为我们的应用大部分时候还是运行在linux环境下的,且平台间的差异性并不会影响我们对nodejs原理的分析和理解。好了,对于nodejs在linux下的I/O模型来说,libuv实际上提供了两种不同场景下的不同实现,处理网络I/O主要由epoll函数实现(其实就是I/O多路复用,在前面的图中使用的是select函数来实现I/O多路复用,而epoll可以理解为select函数的升级版,这个暂时不做具体分析),而处理文件I/O则由多线程(线程池) + 阻塞I/O模拟异步I/O实现


下面是一段我写的nodejs底层实现的伪代码帮助大家理解

listenFd = new Socket();    // 创建监听socket
Bind(listenFd, 80); // 绑定端口
Listen(listenFd);   // 开始监听

for ( ; ; ) {
    // 阻塞在epoll函数上,等待网络数据准备好
    // epoll可同时监听listenFd以及多个客户端连接上是否有数据准备就绪
    // clients表示当前所有客户端连接,curFd表示epoll函数最终拿到的一个就绪的连接
    curFd = Epoll(listenFd, clients);

    if (curFd === listenFd) {
        // 监听套接字收到新的客户端连接,创建套接字
        int connFd = Accept(listenFd);
        // 将新建的连接添加到epoll监听的list
        clients.push(connFd);
    }

    else {
        // 某个客户端连接数据就绪,读取请求数据
        request = curFd.read();
        // 这里拿到请求数据后可以发出data事件进入nodejs的事件循环
        ...
    }
}

// 读取本地文件时,libuv用多线程(线程池) + BIO模拟异步I/O
ThreadPool.run((callback) => {
    // 在线程里用BIO读取文件
    String content = Read('text.txt');  
    // 发出事件调用nodejs提供的callback
});

通过I/O多路复用 + 多线程模拟的异步I/O配合事件循环机制,nodejs就实现了单线程处理并发请求并且不会阻塞。所以回到之前所说的“非阻塞I/O”模型,实际上nodejs并没有直接使用通常定义上的非阻塞I/O模型,而是I/O多路复用模型 + 多线程BIO。我认为“非阻塞I/O”其实更多是对nodejs编程人员来说的一种描述,从编码方式和代码执行顺序上来讲,nodejs的I/O调用的确是“非阻塞”的

总结

至此我们应该可以了解到,nodejs的I/O模型其实主要是由I/O多路复用和多线程下的阻塞I/O两种方式一起组成的,而应对高并发请求时发挥作用的主要就是I/O多路复用。好了,那最后我们来总结一下nodejs线程模型和I/O模型对比传统web应用多进(线)程 + 阻塞I/O模型的优势和劣势

  • nodejs는 단일 스레드 모델을 사용하여 시스템 유지 관리 및 다중 스레드 전환 비용을 절약하는 동시에 다중화 I/O 모델은 nodejs의 단일 스레드가 특정 연결에서 차단되는 것을 방지할 수 있습니다. 동시성이 높은 시나리오에서 nodejs 애플리케이션은 해당 프로세스나 스레드를 생성하지 않고 여러 클라이언트 연결에 해당하는 소켓 설명자만 생성하고 관리하면 됩니다. 시스템 오버헤드가 크게 줄어들므로 동시에 더 많은 클라이언트 연결을 처리할 수 있습니다
  • Nodejs는 불가능합니다. 기본 실제 I/O 작업의 효율성을 향상시킵니다. 기본 I/O가 시스템의 성능 병목 현상을 일으키는 경우 nodejs는 여전히 이를 해결할 수 없습니다. 즉, nodejs는 높은 동시 요청을 받을 수 있지만, 읽기 및 읽기와 같은 많은 수의 느린 I/O 작업을 처리해야 하는 경우입니다. 디스크 쓰기) 여전히 시스템 리소스 과부하가 발생할 수 있습니다. 따라서 단일 스레드 + 비차단 I/O 모델로는 단순히 높은 동시성을 해결할 수 없습니다.
  • CPU 집약적인 애플리케이션은 nodejs의 단일 스레드 모델을 성능 병목 현상으로 만들 수 있습니다.
  • nodejs는 높은 동시성 처리에 적합합니다. 소량의 비즈니스 로직 또는 빠른 I/O(예: 읽기 및 쓰기 메모리)

노드 관련 지식을 더 보려면 nodejs 튜토리얼을 방문하세요!

위 내용은 Node의 높은 동시성 원칙에 대한 간략한 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 掘金社区에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
C/C에서 JavaScript까지 : 모든 것이 어떻게 작동하는지C/C에서 JavaScript까지 : 모든 것이 어떻게 작동하는지Apr 14, 2025 am 12:05 AM

C/C에서 JavaScript로 전환하려면 동적 타이핑, 쓰레기 수집 및 비동기 프로그래밍으로 적응해야합니다. 1) C/C는 수동 메모리 관리가 필요한 정적으로 입력 한 언어이며 JavaScript는 동적으로 입력하고 쓰레기 수집이 자동으로 처리됩니다. 2) C/C를 기계 코드로 컴파일 해야하는 반면 JavaScript는 해석 된 언어입니다. 3) JavaScript는 폐쇄, 프로토 타입 체인 및 약속과 같은 개념을 소개하여 유연성과 비동기 프로그래밍 기능을 향상시킵니다.

JavaScript 엔진 : 구현 비교JavaScript 엔진 : 구현 비교Apr 13, 2025 am 12:05 AM

각각의 엔진의 구현 원리 및 최적화 전략이 다르기 때문에 JavaScript 엔진은 JavaScript 코드를 구문 분석하고 실행할 때 다른 영향을 미칩니다. 1. 어휘 분석 : 소스 코드를 어휘 단위로 변환합니다. 2. 문법 분석 : 추상 구문 트리를 생성합니다. 3. 최적화 및 컴파일 : JIT 컴파일러를 통해 기계 코드를 생성합니다. 4. 실행 : 기계 코드를 실행하십시오. V8 엔진은 즉각적인 컴파일 및 숨겨진 클래스를 통해 최적화하여 Spidermonkey는 유형 추론 시스템을 사용하여 동일한 코드에서 성능이 다른 성능을 제공합니다.

브라우저 너머 : 실제 세계의 JavaScript브라우저 너머 : 실제 세계의 JavaScriptApr 12, 2025 am 12:06 AM

실제 세계에서 JavaScript의 응용 프로그램에는 서버 측 프로그래밍, 모바일 애플리케이션 개발 및 사물 인터넷 제어가 포함됩니다. 1. 서버 측 프로그래밍은 Node.js를 통해 실현되며 동시 요청 처리에 적합합니다. 2. 모바일 애플리케이션 개발은 재교육을 통해 수행되며 크로스 플랫폼 배포를 지원합니다. 3. Johnny-Five 라이브러리를 통한 IoT 장치 제어에 사용되며 하드웨어 상호 작용에 적합합니다.

Next.js (백엔드 통합)로 멀티 테넌트 SAAS 애플리케이션 구축Next.js (백엔드 통합)로 멀티 테넌트 SAAS 애플리케이션 구축Apr 11, 2025 am 08:23 AM

일상적인 기술 도구를 사용하여 기능적 다중 테넌트 SaaS 응용 프로그램 (Edtech 앱)을 구축했으며 동일한 작업을 수행 할 수 있습니다. 먼저, 다중 테넌트 SaaS 응용 프로그램은 무엇입니까? 멀티 테넌트 SAAS 응용 프로그램은 노래에서 여러 고객에게 서비스를 제공 할 수 있습니다.

Next.js (Frontend Integration)를 사용하여 멀티 테넌트 SaaS 응용 프로그램을 구축하는 방법Next.js (Frontend Integration)를 사용하여 멀티 테넌트 SaaS 응용 프로그램을 구축하는 방법Apr 11, 2025 am 08:22 AM

이 기사에서는 Contrim에 의해 확보 된 백엔드와의 프론트 엔드 통합을 보여 주며 Next.js를 사용하여 기능적인 Edtech SaaS 응용 프로그램을 구축합니다. Frontend는 UI 가시성을 제어하기 위해 사용자 권한을 가져오고 API가 역할 기반을 준수하도록합니다.

JavaScript : 웹 언어의 다양성 탐색JavaScript : 웹 언어의 다양성 탐색Apr 11, 2025 am 12:01 AM

JavaScript는 현대 웹 개발의 핵심 언어이며 다양성과 유연성에 널리 사용됩니다. 1) 프론트 엔드 개발 : DOM 운영 및 최신 프레임 워크 (예 : React, Vue.js, Angular)를 통해 동적 웹 페이지 및 단일 페이지 응용 프로그램을 구축합니다. 2) 서버 측 개발 : Node.js는 비 차단 I/O 모델을 사용하여 높은 동시성 및 실시간 응용 프로그램을 처리합니다. 3) 모바일 및 데스크탑 애플리케이션 개발 : 크로스 플랫폼 개발은 개발 효율을 향상시키기 위해 반응 및 전자를 통해 실현됩니다.

JavaScript의 진화 : 현재 동향과 미래 전망JavaScript의 진화 : 현재 동향과 미래 전망Apr 10, 2025 am 09:33 AM

JavaScript의 최신 트렌드에는 Typescript의 Rise, 현대 프레임 워크 및 라이브러리의 인기 및 WebAssembly의 적용이 포함됩니다. 향후 전망은보다 강력한 유형 시스템, 서버 측 JavaScript 개발, 인공 지능 및 기계 학습의 확장, IoT 및 Edge 컴퓨팅의 잠재력을 포함합니다.

Demystifying JavaScript : 그것이하는 일과 중요한 이유Demystifying JavaScript : 그것이하는 일과 중요한 이유Apr 09, 2025 am 12:07 AM

JavaScript는 현대 웹 개발의 초석이며 주요 기능에는 이벤트 중심 프로그래밍, 동적 컨텐츠 생성 및 비동기 프로그래밍이 포함됩니다. 1) 이벤트 중심 프로그래밍을 사용하면 사용자 작업에 따라 웹 페이지가 동적으로 변경 될 수 있습니다. 2) 동적 컨텐츠 생성을 사용하면 조건에 따라 페이지 컨텐츠를 조정할 수 있습니다. 3) 비동기 프로그래밍은 사용자 인터페이스가 차단되지 않도록합니다. JavaScript는 웹 상호 작용, 단일 페이지 응용 프로그램 및 서버 측 개발에 널리 사용되며 사용자 경험 및 크로스 플랫폼 개발의 유연성을 크게 향상시킵니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.