


Encore.ts — Permulaan sejuk yang lebih cepat daripada NestJS & Fastify
Beberapa bulan lalu kami mengeluarkan Encore.ts — rangka kerja bahagian belakang Sumber Terbuka untuk TypeScript.
Memandangkan sudah banyak rangka kerja di luar sana, kami ingin berkongsi beberapa keputusan reka bentuk terpencil yang telah kami buat dan cara ia membawa kepada angka prestasi yang luar biasa.
Kami baru-baru ini menerbitkan penanda aras prestasi yang menunjukkan bahawa Encore.ts mencapai 9x pemprosesan permintaan berbanding Express.js dan 2x berbanding Fastify.
Hari ini, kami meneruskan perjalanan prestasi kami dengan menyelami cara Encore.ts mencapai sangat pantas masa permulaan yang sejuk.
Penanda aras prestasi
Kali ini kami telah menanda aras Encore.ts, Fastify, NestJS dan Express untuk melihat prestasi setiap rangka kerja apabila tiba masa permulaan yang sejuk.
Atur cara penanda aras mendaftarkan 10 titik akhir API, setiap satu dengan skema mudah dan menyediakan pengesahan skema.
Untuk pengesahan skema kami menggunakan Zod jika boleh.
Dalam kes Fastify, kami menggunakan Ajv sebagai pustaka pengesahan skema yang disokong secara rasmi.
Kami mengukur masa dari kod JavaScript mula dilaksanakan sehingga pelayan bersedia untuk menerima permintaan masuk.
Untuk setiap penanda aras kami mengambil keputusan terbaik daripada lima larian.
Cukup cakap, mari kita gali nombor!
Permulaan sejuk Encore.ts adalah 17x lebih pantas daripada NestJS dan Fastify
(Lihat kod penanda aras pada GitHub.)
Seperti yang anda lihat, Encore.ts mencapai masa permulaan sejuk yang pantas, lebih 5x lebih pantas daripada Express dan lebih 17x lebih pantas daripada NestJS.
Bagaimana ini boleh berlaku? Daripada ujian kami, kami telah mengenal pasti dua sumber prestasi utama, kedua-duanya berkaitan dengan cara Encore.ts berfungsi di bawah hud.
Tetapi sebelum kita sampai ke sana, mari kita bincangkan tentang apa sebenarnya permulaan sejuk, dan mengapa ia penting.
Apakah permulaan yang sejuk?
Dalam konteks tanpa pelayan, permulaan yang dingin ialah apabila platform yang mendasari perlu memutarkan tika baharu pelayan anda untuk menyampaikan permintaan masuk. (Ia juga boleh merujuk pada kali pertama tika baharu pelayan anda dimulakan untuk mengendalikan permintaan, contohnya selepas penempatan.)
Memandangkan permintaan ditangguhkan dengan berkesan sehingga proses bermula dan bersedia untuk mengendalikan permintaan, mengurangkan masa permulaan sejuk boleh memberi kesan besar pada kependaman ekor panjang permohonan anda.
Ini amat penting untuk sistem yang diedarkan di mana anda mempunyai berbilang fungsi tanpa pelayan, kerana kemungkinan besar anda akan mengalami permulaan yang sejuk di sesetengah bahagian sistem apabila mengendalikan permintaan.
Anatomi permulaan sejuk
Tepatnya perkara yang berlaku semasa permulaan sejuk bergantung sedikit pada platform yang anda gunakan (Kubernetes, Lambda, Cloud Run, dll.).
Tetapi secara umum, prosesnya kelihatan seperti ini:
- Platform memuat turun kod/imej bekas untuk fungsi tanpa pelayan
- Platform memutarkan contoh baharu bagi bekas/fungsi tanpa pelayan/bekas
- Bekas/fungsi memulakan dirinya sendiri (mengimport modul JavaScript, menjalankan kod permulaan, dsb.)
Selepas langkah permulaan ini, permulaan sejuk selesai dan fungsi tanpa pelayan mula memproses permintaan masuk.
Dua langkah pertama sebahagian besarnya di luar kawalan kami (selain dengan memastikan saiz kod/bekas dioptimumkan), jadi mari kita tumpukan perhatian kita pada langkah ketiga.
Malah, mari kita pecahkan lagi langkah ketiga, dan dengan anggapan kita menjalankan Node.js:
- Proses nod bermula dan mula memulakan enjin JavaScript V8
- Fail titik masuk dihuraikan, dimuatkan dan mula melaksanakan kod aplikasi
- Apabila kod JavaScript melaksanakan import dan memerlukan penyataan, namun lebih banyak fail dimuatkan, dihuraikan dan dilaksanakan. (Ulang banyak kali untuk aplikasi yang mempunyai banyak kebergantungan.)
Akhir sekali, selepas semua kebergantungan telah dimuatkan dan semua kod permulaan telah dilaksanakan, fungsi bekas/tanpa pelayan bersedia untuk mengendalikan permintaan masuk.
Mengoptimumkan permulaan sejuk
Pecahan di atas memberikan kita sasaran yang jelas untuk pengoptimuman dan Encore.ts mengoptimumkan semua langkah yang dikawalnya.
Pengoptimuman 1: Masa jalan karat
Encore.ts dilaksanakan dalam Rust dan dimuatkan ke Node.JS sebagai modul asli. Ini mempunyai beberapa faedah untuk permulaan sejuk:
Kurang JavaScript untuk dihuraikan dan dilaksanakan. Memandangkan JavaScript ialah bahasa yang ditafsirkan, semua kod JavaScript perlu dibaca daripada cakera, dihuraikan dan dilaksanakan. Encore.ts, sebagai modul asli yang telah dikompilasi, dimuatkan dengan sangat cepat dan tidak perlu dihuraikan atau dilaksanakan oleh enjin JavaScript (V8).
Sifar NPM tanggungan. Memandangkan Encore.ts melaksanakan semua fungsinya menggunakan Rust, ia tidak mempunyai sebarang kebergantungan NPM, yang seterusnya mengurangkan jumlah JavaScript yang perlu dilaksanakan semasa permulaan sejuk.
Pra-disusun dan dioptimumkan. JavaScript sangat bergantung pada kompilasi tepat dalam masa (JIT), di mana kod yang dilaksanakan berulang kali akan dioptimumkan oleh enjin JavaScript. Ini sangat masuk akal untuk bahasa yang ditafsirkan, tetapi ini juga bermakna pelaksanaan agak perlahan pada kali pertama sekeping kod dijalankan, yang memberi kesan kepada permulaan sejuk dengan ketara. Memandangkan Encore.ts dilaksanakan dalam Rust, ia telah disusun terlebih dahulu dan sangat dioptimumkan untuk platform yang sedang dijalankan, yang bermaksud ia pantas dari kali pertama ia dilaksanakan.
Pengoptimuman 2: Imej Docker yang cekap
Encore.ts secara lalai membina imej Docker yang diperkecil, dengan hanya memasukkan JavaScript yang ditranspilkan dan kebergantungan yang diperlukan untuk menjalankan aplikasi. Ini mengurangkan saiz berkas, yang seterusnya mengurangkan masa yang diperlukan untuk memuat turun dan memulakan bekas.
Selain itu, beberapa platform pengiraan telah menambah sokongan untuk menstrim imej Docker, yang bermaksud bahawa platform boleh memulakan bekas sebelum keseluruhan imej telah dimuat turun. Encore.ts mempunyai sokongan terbina dalam untuk ini dan secara automatik mengutamakan bahagian imej yang diperlukan untuk mengurangkan permulaan sejuk.
Membungkus
Dengan menggabungkan masa jalan Rust dengan imej Docker yang dioptimumkan, Encore.ts dapat mencapai masa mula sejuk yang luar biasa, yang boleh memberi kesan besar pada kependaman ekor panjang aplikasi anda.
Jika prestasi penting untuk projek anda, mungkin idea yang baik untuk mencuba Encore.ts.
Dan semuanya adalah Sumber Terbuka, jadi anda boleh menyemak kod dan menyumbang di GitHub.
Atau cuba sahaja dan beritahu kami pendapat anda!
Atas ialah kandungan terperinci Encore.ts — Permulaan sejuk yang lebih cepat daripada NestJS & Fastify. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas











JavaScript adalah asas kepada pembangunan web moden, dan fungsi utamanya termasuk pengaturcaraan yang didorong oleh peristiwa, penjanaan kandungan dinamik dan pengaturcaraan tak segerak. 1) Pengaturcaraan yang didorong oleh peristiwa membolehkan laman web berubah secara dinamik mengikut operasi pengguna. 2) Penjanaan kandungan dinamik membolehkan kandungan halaman diselaraskan mengikut syarat. 3) Pengaturcaraan Asynchronous memastikan bahawa antara muka pengguna tidak disekat. JavaScript digunakan secara meluas dalam interaksi web, aplikasi satu halaman dan pembangunan sisi pelayan, sangat meningkatkan fleksibiliti pengalaman pengguna dan pembangunan silang platform.

Trend terkini dalam JavaScript termasuk kebangkitan TypeScript, populariti kerangka dan perpustakaan moden, dan penerapan webassembly. Prospek masa depan meliputi sistem jenis yang lebih berkuasa, pembangunan JavaScript, pengembangan kecerdasan buatan dan pembelajaran mesin, dan potensi pengkomputeran IoT dan kelebihan.

Enjin JavaScript yang berbeza mempunyai kesan yang berbeza apabila menguraikan dan melaksanakan kod JavaScript, kerana prinsip pelaksanaan dan strategi pengoptimuman setiap enjin berbeza. 1. Analisis leksikal: Menukar kod sumber ke dalam unit leksikal. 2. Analisis Tatabahasa: Menjana pokok sintaks abstrak. 3. Pengoptimuman dan Penyusunan: Menjana kod mesin melalui pengkompil JIT. 4. Jalankan: Jalankan kod mesin. Enjin V8 mengoptimumkan melalui kompilasi segera dan kelas tersembunyi, Spidermonkey menggunakan sistem kesimpulan jenis, menghasilkan prestasi prestasi yang berbeza pada kod yang sama.

JavaScript adalah bahasa utama pembangunan web moden dan digunakan secara meluas untuk kepelbagaian dan fleksibiliti. 1) Pembangunan front-end: Membina laman web dinamik dan aplikasi satu halaman melalui operasi DOM dan kerangka moden (seperti React, Vue.js, sudut). 2) Pembangunan sisi pelayan: Node.js menggunakan model I/O yang tidak menyekat untuk mengendalikan aplikasi konkurensi tinggi dan masa nyata. 3) Pembangunan aplikasi mudah alih dan desktop: Pembangunan silang platform direalisasikan melalui reaktnatif dan elektron untuk meningkatkan kecekapan pembangunan.

Python lebih sesuai untuk pemula, dengan lengkung pembelajaran yang lancar dan sintaks ringkas; JavaScript sesuai untuk pembangunan front-end, dengan lengkung pembelajaran yang curam dan sintaks yang fleksibel. 1. Sintaks Python adalah intuitif dan sesuai untuk sains data dan pembangunan back-end. 2. JavaScript adalah fleksibel dan digunakan secara meluas dalam pengaturcaraan depan dan pelayan.

Artikel ini menunjukkan integrasi frontend dengan backend yang dijamin oleh permit, membina aplikasi edtech SaaS yang berfungsi menggunakan Next.Js. Frontend mengambil kebenaran pengguna untuk mengawal penglihatan UI dan memastikan permintaan API mematuhi dasar peranan

Peralihan dari C/C ke JavaScript memerlukan menyesuaikan diri dengan menaip dinamik, pengumpulan sampah dan pengaturcaraan asynchronous. 1) C/C adalah bahasa yang ditaip secara statik yang memerlukan pengurusan memori manual, manakala JavaScript ditaip secara dinamik dan pengumpulan sampah diproses secara automatik. 2) C/C perlu dikumpulkan ke dalam kod mesin, manakala JavaScript adalah bahasa yang ditafsirkan. 3) JavaScript memperkenalkan konsep seperti penutupan, rantaian prototaip dan janji, yang meningkatkan keupayaan pengaturcaraan fleksibiliti dan asynchronous.

Saya membina aplikasi SaaS multi-penyewa berfungsi (aplikasi edTech) dengan alat teknologi harian anda dan anda boleh melakukan perkara yang sama. Pertama, apakah aplikasi SaaS multi-penyewa? Aplikasi SaaS Multi-penyewa membolehkan anda melayani beberapa pelanggan dari Sing
