몇 달 전 우리는 TypeScript용 오픈 소스 백엔드 프레임워크인 Encore.ts를 출시했습니다.
이미 많은 프레임워크가 있으므로 우리는 우리가 내린 특이한 디자인 결정 중 일부와 이것이 어떻게 놀라운 성능 수치로 이어지는지 공유하고 싶습니다.
최근에 Encore.ts가 Express.js에 비해 9배, Fastify에 비해 2배의 요청 처리량을 달성했음을 보여주는 성능 벤치마크를 발표했습니다.
오늘 우리는 Encore.ts가 어떻게 놀라울 정도로 빠른 콜드 스타트 시작 시간을 달성했는지 살펴보며 성능 여정을 계속하겠습니다.
성능 벤치마크
이번에는 Encore.ts, Fastify, NestJS 및 Express를 벤치마킹하여 콜드 시작 시간에 각 프레임워크가 어떻게 작동하는지 확인했습니다.
벤치마크 프로그램은 각각 간단한 스키마가 포함된 10개의 API 엔드포인트를 등록하고 스키마 유효성 검사를 설정합니다.
스키마 검증을 위해 가능한 경우 Zod를 사용했습니다.
Fastify의 경우 공식적으로 지원되는 스키마 검증 라이브러리로 Ajv를 사용했습니다.
JavaScript 코드가 실행되기 시작한 시점부터 서버가 들어오는 요청을 수락할 준비가 될 때까지의 시간을 측정했습니다.
각 벤치마크에 대해 우리는 5번의 실행에서 가장 좋은 결과를 얻었습니다.
말은 이제 그만, 숫자로 파헤쳐봅시다!
Encore.ts 콜드 스타트는 NestJS 및 Fastify보다 17배 빠릅니다.
(GitHub에서 벤치마크 코드를 확인하세요.)
보시다시피 Encore.ts는 Express보다 5배 이상, NestJS보다 17배 이상 빠른 콜드 시작 시간을 달성했습니다.
어떻게 이것이 가능합니까? 테스트를 통해 Encore.ts의 내부 작동 방식과 관련된 두 가지 주요 성능 소스를 확인했습니다.
하지만 거기에 도달하기 전에 콜드 스타트가 실제로 무엇인지, 그리고 그것이 왜 중요한지에 대해 이야기해 보겠습니다.
콜드 스타트란 무엇입니까?
서버리스의 맥락에서 콜드 스타트는 기본 플랫폼이 들어오는 요청을 처리하기 위해 먼저 서버의 새 인스턴스를 가동해야 하는 경우입니다. (예를 들어 배포 후 요청을 처리하기 위해 서버의 새 인스턴스가 처음 시작되는 것을 의미할 수도 있습니다.)
프로세스가 시작되고 요청을 처리할 준비가 될 때까지 요청이 사실상 보류되므로 콜드 시작 시간을 줄이면 애플리케이션의 롱테일 대기 시간에 큰 영향을 미칠 수 있습니다.
요청을 처리할 때 시스템 일부에서 콜드 스타트가 발생할 가능성이 훨씬 높기 때문에 여러 서버리스 기능이 있는 분산 시스템에 특히 중요합니다.
콜드 스타트의 구조
콜드 스타트 중에 발생하는 정확한 상황은 배포하는 플랫폼(Kubernetes, Lambda, Cloud Run 등)에 따라 조금씩 다릅니다.
그러나 일반적으로 프로세스는 다음과 같습니다.
- 플랫폼에서 서버리스 기능을 위한 코드/컨테이너 이미지를 다운로드합니다
- 플랫폼은 컨테이너/서버리스 기능/컨테이너의 새로운 인스턴스를 가동합니다
- 컨테이너/함수는 자체적으로 초기화됩니다(JavaScript 모듈 가져오기, 초기화 코드 실행 등)
이러한 초기화 단계 후에 콜드 스타트가 완료되고 서버리스 기능이 들어오는 요청 처리를 시작합니다.
처음 두 단계는 대부분 우리가 제어할 수 없으므로(코드/컨테이너의 크기를 최적화하는 것 제외) 세 번째 단계에 집중하겠습니다.
사실 세 번째 단계를 더 자세히 살펴보고 Node.js를 실행한다고 가정하겠습니다.
- 노드 프로세스가 시작되고 V8 JavaScript 엔진 초기화가 시작됩니다
- 진입점 파일이 구문 분석되고 로드되고 애플리케이션 코드 실행이 시작됩니다
- JavaScript 코드가 import 및 require 문을 실행하면 더 많은 파일이 로드되고 구문 분석되고 실행됩니다. (종속성이 많은 애플리케이션의 경우 여러 번 반복합니다.)
마지막으로 모든 종속성이 로드되고 모든 초기화 코드가 실행되면 컨테이너/서버리스 기능이 들어오는 요청을 처리할 준비가 됩니다.
콜드 스타트 최적화
위의 분석은 최적화를 위한 명확한 목표를 제공하며 Encore.ts는 제어할 수 있는 모든 단계를 대폭 최적화합니다.
최적화 1: Rust 런타임
Encore.ts는 Rust로 구현되어 Node.JS에 기본 모듈로 로드됩니다. 콜드 스타트에는 여러 가지 이점이 있습니다.
파싱하고 실행할 JavaScript가 적습니다. JavaScript는 해석된 언어이므로 모든 JavaScript 코드를 디스크에서 읽고, 구문 분석하고, 실행해야 합니다. 사전 컴파일된 기본 모듈인 Encore.ts는 매우 빠르게 로드되며 JavaScript 엔진(V8)에서 구문 분석하거나 실행할 필요가 없습니다.
NPM 종속성이 없습니다. Encore.ts는 Rust를 사용하여 모든 기능을 구현하므로 NPM 종속성이 전혀 없으므로 콜드 스타트 중에 실행해야 하는 JavaScript의 양이 더욱 줄어듭니다.
사전 컴파일 및 최적화. JavaScript는 반복적으로 실행되는 코드가 JavaScript 엔진에 의해 최적화되는 JIT(Just-In-Time 컴파일)에 크게 의존합니다. 이는 해석된 언어의 경우 많은 의미가 있지만 코드 조각이 처음 실행될 때 실행이 상당히 느려져 콜드 스타트에 상당한 영향을 미친다는 의미이기도 합니다. Encore.ts는 Rust로 구현되므로 실행 중인 플랫폼에 맞게 사전 컴파일되고 최적화되어 있어 처음 실행될 때부터 속도가 빠릅니다.
최적화 2: 효율적인 Docker 이미지
Encore.ts는 기본적으로 변환된 JavaScript와 애플리케이션 실행에 필요한 종속성만 포함하여 축소된 Docker 이미지를 구축합니다. 이렇게 하면 번들 크기가 줄어들고 결과적으로 컨테이너를 다운로드하고 시작하는 데 걸리는 시간이 줄어듭니다.
또한 여러 컴퓨팅 플랫폼에 Docker 이미지 스트리밍에 대한 지원이 추가되었습니다. 즉, 전체 이미지가 다운로드되기 전에 플랫폼에서 컨테이너를 시작할 수 있습니다. Encore.ts에는 이를 위한 지원 기능이 내장되어 있으며 콜드 스타트를 줄이는 데 필요한 이미지 부분의 우선 순위를 자동으로 지정합니다.
마무리
Rust 런타임과 최적화된 Docker 이미지를 결합함으로써 Encore.ts는 놀라운 콜드 스타트 시간을 달성할 수 있으며 이는 애플리케이션의 롱테일 대기 시간에 큰 영향을 미칠 수 있습니다.
프로젝트에 성능이 중요하다면 Encore.ts를 사용해 보는 것이 좋습니다.
그리고 모두 오픈 소스이므로 코드를 확인하고 GitHub에 기여할 수 있습니다.
아니면 한번 시도해 보시고 의견을 알려주세요!
위 내용은 Encore.ts — NestJS 및 Fastify보다 빠른 콜드 스타트의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

JavaScript 문자열 교체 방법 및 FAQ에 대한 자세한 설명 이 기사는 JavaScript에서 문자열 문자를 대체하는 두 가지 방법 인 내부 JavaScript 코드와 웹 페이지의 내부 HTML을 탐색합니다. JavaScript 코드 내부의 문자열을 교체하십시오 가장 직접적인 방법은 대체 () 메소드를 사용하는 것입니다. str = str.replace ( "find", "replace"); 이 메소드는 첫 번째 일치 만 대체합니다. 모든 경기를 교체하려면 정규 표현식을 사용하고 전역 플래그 g를 추가하십시오. str = str.replace (/fi

간단한 자바 스크립트 함수는 날짜가 유효한지 확인하는 데 사용됩니다. 기능 isValidDate (s) { var 비트 = s.split ( '/'); var d = 새로운 날짜 (비트 [2]/'비트 [1]/'비트 [0]); return !! (d && (d.getmonth () 1) == 비트 [1] && d.getDate () == 숫자 (비트 [0]); } //시험 var

이 기사에서는 jQuery를 사용하여 DOM 요소의 내부 마진 및 마진 값, 특히 요소의 외부 마진 및 내부 마진의 특정 위치를 얻고 설정하는 방법에 대해 설명합니다. CSS를 사용하여 요소의 내부 및 외부 마진을 설정할 수는 있지만 정확한 값을 얻는 것이 까다로울 수 있습니다. // 설정 $ ( "div.header"). css ( "margin", "10px"); $ ( "Div.Header"). CSS ( "패딩", "10px"); 이 코드는 생각할 수 있습니다

이 기사는 10 개의 탁월한 jQuery 탭과 아코디언을 탐구합니다. 탭과 아코디언의 주요 차이점은 콘텐츠 패널이 표시되고 숨겨진 방식에 있습니다. 이 10 가지 예를 살펴 보겠습니다. 관련 기사 : 10 JQuery Tab 플러그인

웹 사이트의 역학 및 시각적 매력을 높이기 위해 10 개의 탁월한 jQuery 플러그인을 발견하십시오! 이 선별 된 컬렉션은 이미지 애니메이션에서 대화식 갤러리에 이르기까지 다양한 기능을 제공합니다. 이 강력한 도구를 탐색합시다. 관련 게시물 : 1

HTTP-Console은 HTTP 명령을 실행하기위한 명령 줄 인터페이스를 제공하는 노드 모듈입니다. 웹 서버, 웹 서비스에 대해 만들어 졌는지 여부에 관계없이 HTTP 요청과 함께 어떻게 진행되고 있는지 정확하게 보는 데 유용합니다.

이 튜토리얼은 사용자 정의 Google 검색 API를 블로그 또는 웹 사이트에 통합하는 방법을 보여 주며 표준 WordPress 테마 검색 기능보다보다 세련된 검색 경험을 제공합니다. 놀랍게도 쉽습니다! 검색을 Y로 제한 할 수 있습니다

다음 jQuery 코드 스 니펫은 DIV 내용이 컨테이너 요소 영역을 초과 할 때 스크롤 바를 추가하는 데 사용될 수 있습니다. (데모 없음, FireBug에 직접 복사하십시오) // d = 문서 // w = 창 // $ = jQuery var contentArea = $ (this), wintop = contentArea.scrolltop (), docheight = $ (d) .height (), winheight = $ (w) .height (), divheight = $ ( '#c


핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

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

드림위버 CS6
시각적 웹 개발 도구

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