Kolam sambungan permintaan Node.js: komponen utama untuk meningkatkan prestasi dan kebolehskalaan
Dalam aplikasi yang dibina pada Node.js, jika terdapat sejumlah besar permintaan rangkaian, maka kumpulan sambungan akan menjadi sangat Alat yang berguna. Pengumpulan sambungan bukan sahaja meningkatkan prestasi aplikasi tetapi juga memastikan ia boleh berskala. Dalam artikel ini, kami akan meneroka apakah pengumpulan sambungan dan cara menggunakannya dalam aplikasi Node.js anda untuk meningkatkan prestasi dan kebolehskalaan.
Apakah kolam sambungan?
Kolam sambungan ialah alat untuk mengurus dan mengekalkan sambungan rangkaian seperti sambungan pangkalan data dan sambungan HTTP. Biasanya, aplikasi perlu meminta sambungan daripada sumber, seperti pelayan pangkalan data. Dalam situasi trafik yang tinggi, aplikasi mungkin perlu meminta berbilang sambungan daripada sumber yang sama, yang boleh menyebabkan keletihan sumber dan aplikasi menjadi tidak tersedia.
Nasib baik, peranan kumpulan sambungan adalah untuk mengekalkan koleksi sambungan yang tersedia. Aplikasi boleh mendapatkan sambungan daripada kumpulan sambungan tanpa mencipta semula sambungan. Ini bukan sahaja menjimatkan masa, tetapi juga mengelakkan overhed untuk mencipta semula sambungan sumber untuk setiap permintaan.
Kolam sambungan boleh mengurus pelbagai jenis sambungan, termasuk sambungan pangkalan data, sambungan HTTP dan sebarang sambungan sumber rangkaian boleh guna semula yang lain. Dalam artikel ini, kami akan menumpukan pada kes menggunakan pengumpulan sambungan untuk mengurus sambungan HTTP.
Gunakan pengumpulan sambungan untuk meningkatkan prestasi aplikasi
Dalam situasi trafik yang tinggi, pengumpulan sambungan boleh meningkatkan prestasi aplikasi dengan sangat baik. Mari lihat contoh, katakan kita mempunyai aplikasi Node.js yang membuat 100 permintaan HTTP sesaat. Jika kami tidak menggunakan kumpulan sambungan, setiap permintaan akan mengambil masa tertentu untuk membuat sambungan baharu. Dalam situasi trafik yang tinggi, overhed ini akan berkembang secara eksponen dan menjadi tidak mampu dimiliki. Dengan menggunakan kumpulan sambungan, kami boleh mendapatkan sambungan HTTP yang tersedia dari kumpulan pada masa yang sama, mengelakkan kos mencipta semula sambungan, sekali gus meningkatkan prestasi.
Gunakan pengumpulan sambungan untuk meningkatkan kebolehskalaan aplikasi
Dalam aplikasi dengan ramai pengguna serentak, pengumpulan sambungan juga boleh meningkatkan kebolehskalaan. Ini kerana setiap permintaan HTTP memerlukan sambungan, dan setiap sambungan menggunakan sumber I/O sistem. Jika kami tidak menguruskan sambungan, maka setiap sambungan akan menjadi longkang pada sumber sistem dan boleh menyebabkan kehabisan sumber sistem. Menggunakan kolam sambungan boleh mengelakkan situasi ini, dan kami boleh mengehadkan bilangan sambungan untuk memastikan sumber sistem tidak diduduki selama-lamanya. Melakukannya bukan sahaja meningkatkan kebolehskalaan aplikasi, tetapi juga mengelakkan kerugian yang disebabkan oleh masa henti sistem semasa trafik tinggi.
Melaksanakan Pengumpulan Sambungan
Baiklah, kini kita tahu faedah pengumpulan sambungan, jadi bagaimana kita melaksanakannya dalam aplikasi Node.js? Malah, Node.js mempunyai modul kolam sambungan terbina dalam: http.Agent. http.Agent digunakan untuk menguruskan kumpulan sambungan untuk permintaan klien HTTP Bilangan sambungan boleh dihadkan melalui pilihan maxSockets.
Sebagai contoh, kod berikut menggunakan http.Agent untuk melaksanakan kumpulan sambungan:
const http = require('http'); const maxConns = 10; const agent = new http.Agent({ maxSockets: maxConns }); for (let i = 0; i < 20; i++) { http.get('http://www.example.com', { agent }, (resp) => { let data = ''; resp.on('data', (chunk) => { data += chunk; }); resp.on('end', () => { console.log(`got response ${i}: ${data}`); }); }).on("error", (err) => { console.log("Error: " + err.message); }); }
Dalam kod di atas, kami mencipta contoh http.Agent dan menyerahkannya kepada pilihan ejen permintaan HTTP . Apabila kami membuat permintaan, http.Agent akan digunakan untuk mengatur sambungan permintaan dan memanggil kaedah http.get(). Memandangkan bilangan maksimum sambungan kami terhad kepada 10, kami hanya boleh mempunyai 10 sambungan dalam kolam pada masa yang sama.
Kami juga boleh menggunakan perpustakaan luaran untuk mempunyai kawalan yang lebih lengkap ke atas kumpulan sambungan. Berikut ialah beberapa perpustakaan kumpulan sambungan yang tersedia:
Perpustakaan ini membenarkan anda mengawal bilangan sambungan dalam kumpulan sambungan, dan cara menguruskan penciptaan sambungan baharu dan pelepasan sambungan yang telah digunakan. Ini sangat berguna apabila membina aplikasi berprestasi tinggi dan berskala.
Ringkasan
Menggunakan pengumpulan sambungan dalam aplikasi Node.js ialah komponen penting untuk meningkatkan prestasi dan kebolehskalaan. Modul kumpulan sambungan http.Agent ialah perpustakaan kumpulan sambungan terbina dalam Node.js, yang boleh digunakan untuk pengurusan kumpulan sambungan permintaan klien HTTP Perpustakaan pihak ketiga generic-pool, generic-pool-mysql dan mysql2 boleh. menyediakan kolam sambungan yang lebih lengkap. Penggunaan kumpulan sambungan boleh mengurangkan keletihan sumber, meningkatkan kelajuan tindak balas permintaan dan menjadikan aplikasi lebih berskala dan teguh.
Atas ialah kandungan terperinci kolam sambungan permintaan nodejs. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!