>  기사  >  웹 프론트엔드  >  비동기 리소스란 무엇입니까? 비동기 자원 컨텍스트 공유를 구현하는 Node의 방법에 대한 간략한 분석

비동기 리소스란 무엇입니까? 비동기 자원 컨텍스트 공유를 구현하는 Node의 방법에 대한 간략한 분석

青灯夜游
青灯夜游앞으로
2022-05-31 12:56:192662검색

Node.js는 비동기 리소스 컨텍스트 공유를 어떻게 구현하나요? 다음 글에서는 Node가 비동기 리소스 컨텍스트 공유를 구현하는 방법을 소개합니다. 모두에게 도움이 되기를 바랍니다.

비동기 리소스란 무엇입니까? 비동기 자원 컨텍스트 공유를 구현하는 Node의 방법에 대한 간략한 분석

비동기 리소스 컨텍스트 공유는 네트워크 요청 수명 주기 또는 비동기 리소스 호출 체인 내에서 컨텍스트 데이터를 공유하는 것을 의미합니다.

이 질문에 답하기 전에 먼저 비동기 리소스가 무엇인지 이해해야 합니다.

비동기 리소스

비동기 리소스는 Promise, Timeouts, TCPWrap, UDP 등과 같은 콜백이 있는 객체로 이해될 수 있습니다. 자세한 내용은 비동기 리소스 유형 목록을 참조하세요.

공식 정의는 다음과 같습니다.

비동기 리소스는 연결된 콜백이 있는 객체를 나타냅니다. 이 콜백은 net.createServer()의 '연결' 이벤트와 같이 여러 번 호출되거나 한 번만 호출될 수 있습니다. fs .open()과 마찬가지로 콜백이 호출되기 전에 리소스를 닫을 수도 있습니다.

AsyncLocalStorage

여기에 소개된 것은 Node.js에서 제공하는 공식 비동기 컨텍스트 공유 솔루션입니다. 16.4.0 이전에는 실험적 기능이었으며 16.4.0 이후로는 안정적이었습니다.

AsyncLocalStorage는 비동기 작업 체인에서 데이터를 공유할 수 있습니다.

AsyncLocalStorage 인스턴스 asyncLocalStorage에는 다음과 같은 주요 메서드가 있습니다.

  • disable()은 asyncLocalStorage를 비활성화합니다.
  • getStore()는 비동기 컨텍스트 초기화를 위해 asyncLocalStorage.run() 또는 asyncLocalStorage.enterWith()를 사용해야 하는 현재 컨텍스트 저장소를 반환합니다.
  • enterWith(store) 이 메소드를 통해 컨텍스트 저장소를 전달하면 모든 후속 비동기 호출에서 저장소를 얻을 수 있습니다.

예:

const store = { id: 1 };
// Replaces previous store with the given store object
asyncLocalStorage.enterWith(store);
asyncLocalStorage.getStore(); // Returns the store object
someAsyncOperation(() => {
  asyncLocalStorage.getStore(); // Returns the same object
});
  • run(store, callback[, ...args] ) 사용 실행하여 컨텍스트 저장소와 해당 유효 콜백 함수를 지정합니다. 저장소는 콜백 함수에서만 가져옵니다.
  • exit(callback[, ...args])

asyncLocalStorage.run() 함수의 첫 번째 매개변수는 비동기 호출에서 액세스해야 하는 공유 데이터를 저장하는 것이고 두 번째 매개변수는 비동기 함수입니다. .

다음은 AsyncLocalStorage를 사용하여 비동기 리소스 컨텍스트 공유를 구현하는 방법을 보여주는 예입니다.

비동기 리소스란 무엇입니까? 비동기 자원 컨텍스트 공유를 구현하는 Node의 방법에 대한 간략한 분석

출력:

runA 8f19ebef-58d7-4b1a-8b9b-46d158beb5d2 2022/5/24 20:26:17 this is a log message
runB 8f19ebef-58d7-4b1a-8b9b-46d158beb5d2 2022/5/24 20:26:17 this is a log message

asyncLocalStorage.run을 통해 실행되는 동일한 비동기 함수에서 runA 함수와 runB 함수가 실행됩니다. runA와 runB는 동일한 컨텍스트 데이터에 액세스할 수 있습니다.

성능 문제

AsyncLocalStorage는 Node.js에서 비동기 리소스 컨텍스트 공유를 쉽게 구현할 수 있는 뛰어난 순회 기능을 제공하지만 모든 비동기 리소스 작업은 비동기 후크를 트리거하므로 필연적으로 노드 성능에 특정 영향을 미칩니다. 애플리케이션. . 그럼 그 영향은 얼마나 큽니까?

Kuzzle의 실제 측정에 따르면 AsyncLocalStorage를 사용하면 약 8%의 추가 성능 손실이 발생합니다. 물론 비즈니스 시나리오에 따라 성능이 다를 수 있습니다. 성능의 이 부분이 우려되는 경우 비즈니스에 비교 테스트를 추가하여 특정 성능 영향을 테스트할 수도 있습니다.

--- AsyncLocalStorage로 기록 log classic difference
req/s 2613 2842 ~8 %

응용 시나리오

다른 다중 스레드 언어에서는 각 HTTP가 새 스레드를 생성하고 각 스레드에는 자체 메모리가 있습니다. 전역 상태를 스레드 메모리에 저장하고 코드 어디에서나 전역 상태를 검색할 수 있습니다.

Node.js에서는 Node.js가 단일 스레드이고 모든 HTTP 요청에서 메모리를 공유하기 때문에 각 HTTP 요청은 상호 격리된 전역 상태를 보유할 수 없습니다.

AsyncLocalStorage는 서로 다른 비동기 작업 간의 상태를 효과적으로 격리할 수 있으며 HTTP 요청 추적, APM 도구, 컨텍스트 로그 추적 및 요청 기반 전체 링크 로그 추적과 같은 시나리오에서 매우 중요한 역할을 합니다.

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

위 내용은 비동기 리소스란 무엇입니까? 비동기 자원 컨텍스트 공유를 구현하는 Node의 방법에 대한 간략한 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 juejin.cn에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제