


Apakah sumber tak segerak? Analisis ringkas kaedah Node untuk merealisasikan perkongsian konteks sumber tak segerak
Bagaimanakah Node.js melaksanakan perkongsian konteks sumber tak segerak? Artikel berikut akan memperkenalkan kepada anda cara Node melaksanakan perkongsian konteks sumber tak segerak Mari kita bincangkan tentang penggunaan perkongsian konteks sumber tak segerak untuk kita.
Perkongsian konteks sumber tak segerak bermaksud berkongsi data konteks dalam kitaran hayat permintaan rangkaian atau rantaian panggilan sumber tak segerak.
Sebelum menjawab soalan ini, kita mesti memahami dahulu apa itu sumber tak segerak.
Sumber tak segerak
Sumber tak segerak boleh difahami sebagai objek dengan panggilan balik, seperti tetapi tidak terhad kepada Janji, Tamat Masa, TCPWrap, UDP, dsb. Untuk butiran, lihat Senarai jenis sumber tak segerak.
Takrifan rasmi adalah seperti berikut:
Sumber tak segerak mewakili objek dengan panggilan balik yang berkaitan ini boleh dipanggil beberapa kali, seperti acara 'sambungan' dalam net .createServer( ), atau hanya sekali seperti dalam fs.open(Sesuatu sumber juga boleh ditutup sebelum panggilan balik dipanggil.
AsyncLocalStorage
di sini Memperkenalkan AsyncLocalStorage, penyelesaian perkongsian konteks tak segerak yang disediakan secara rasmi olehNode.js Ciri ini masih merupakan ciri percubaan sebelum 16.4.0 dan telah stabil sejak 16.4.0.
AsyncLocalStorage boleh berkongsi data dalam rantaian operasi tak segerak. Instance AsyncLocalStorage asyncLocalStorage mempunyai kaedah utama berikut:- disable() disables asyncLocalStorage
- getStore() mengembalikan stor konteks semasa, yang mesti lulus asyncLocalStorage; run() atau asyncLocalStorage.enterWith() untuk melakukan pemulaan konteks asynchronous;
- enterWith(store) melepasi stor konteks melalui kaedah ini, dan kedai boleh diperolehi dalam semua panggilan tak segerak berikutnya; >
- Contoh:
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 });
- exit(callback[, ...args])
- asyncLocalStorage.run() Parameter pertama fungsi adalah untuk menyimpan data kongsi yang perlu kita akses dalam panggilan tak segerak Parameter kedua ialah fungsi tak segerak.
Output:
Oleh asyncLocalStorage Dalam fungsi asynchronous yang sama yang dijalankan oleh .run, fungsi runA dan runB akan dijalankan dan runA dan runB boleh mengakses data konteks yang sama.
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
Isu prestasi
AsyncLocalStorage menyediakan laluan yang hebat untuk kami melaksanakan perkongsian konteks sumber tak segerak dengan mudah dalam Node.js, tetapi setiap operasi sumber tak segerak akan mencetuskan Async Hooks , akan pasti mempunyai kesan tertentu terhadap prestasi aplikasi Node kami. Jadi berapa besar kesannya?
Menurut ukuran sebenar olehKuzzle
, menggunakan AsyncLocalStorage akan menyebabkan kehilangan prestasi tambahan sebanyak 8% Sudah tentu, senario perniagaan yang berbeza mungkin mempunyai prestasi yang berbeza. Jika anda bimbang tentang bahagian prestasi ini, anda juga boleh menambah ujian perbandingan pada perniagaan anda untuk menguji kesan prestasi tertentu. Senario aplikasi---- | Log with AsyncLocalStorage | Log classic | difference |
---|---|---|---|
req/s | 2613 | 2842 | 〜8% |
Dalam bahasa berbilang benang lain, setiap HTTP mencipta urutan baharu dan setiap utas mempunyai ingatan sendiri. Anda boleh menyimpan keadaan global dalam memori benang dan mendapatkan semula keadaan global dari mana-mana sahaja dalam kod anda.
Dalam Node.js, kerana Node.js adalah satu-benang dan berkongsi memori antara semua permintaan HTTP, setiap permintaan HTTP tidak boleh memegang keadaan global yang saling terasing. AsyncLocalStorage boleh mengasingkan status dengan berkesan antara operasi tak segerak yang berbeza, dan memainkan peranan yang sangat penting dalam senario seperti penjejakan permintaan HTTP, alatan APM, penjejakan log konteks dan penjejakan log pautan penuh berasaskan permintaan. Untuk lebih banyak pengetahuan berkaitan nod, sila lawati:tutorial nodejs
!Atas ialah kandungan terperinci Apakah sumber tak segerak? Analisis ringkas kaedah Node untuk merealisasikan perkongsian konteks sumber tak segerak. 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

AI Hentai Generator
Menjana ai hentai secara percuma.

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



Perkhidmatan Node yang dibina berdasarkan bukan sekatan dan dipacu peristiwa mempunyai kelebihan penggunaan memori yang rendah dan sangat sesuai untuk mengendalikan permintaan rangkaian besar-besaran. Di bawah premis permintaan besar-besaran, isu yang berkaitan dengan "kawalan memori" perlu dipertimbangkan. 1. Mekanisme kutipan sampah V8 dan had ingatan Js dikawal oleh mesin kutipan sampah

Artikel ini akan memberi anda pemahaman yang mendalam tentang memori dan pengumpul sampah (GC) enjin NodeJS V8 saya harap ia akan membantu anda!

Bagaimana untuk mengendalikan muat naik fail? Artikel berikut akan memperkenalkan kepada anda cara menggunakan ekspres untuk mengendalikan muat naik fail dalam projek nod saya harap ia akan membantu anda!

Modul fail ialah enkapsulasi operasi fail asas, seperti membaca/menulis/membuka/menutup/memadam fail, dsb. Ciri terbesar modul fail ialah semua kaedah menyediakan dua versi **segerak** dan ** asynchronous**, dengan Kaedah dengan akhiran penyegerakan adalah semua kaedah penyegerakan, dan kaedah yang tidak semuanya adalah kaedah heterogen.

Artikel ini akan berkongsi dengan anda alat pengurusan proses Node "pm2", dan bercakap tentang mengapa pm2 diperlukan, cara memasang dan menggunakan pm2, saya harap ia akan membantu semua orang!

Penjelasan dan Panduan Pemasangan Terperinci untuk Pinetwork Nodes Artikel ini akan memperkenalkan ekosistem pinetwork secara terperinci - nod pi, peranan utama dalam ekosistem pinetwork, dan menyediakan langkah -langkah lengkap untuk pemasangan dan konfigurasi. Selepas pelancaran Rangkaian Ujian Blockchain Pinetwork, nod PI telah menjadi bahagian penting dari banyak perintis yang aktif mengambil bahagian dalam ujian, bersiap sedia untuk pelepasan rangkaian utama yang akan datang. Jika anda tidak tahu kerja pinet, sila rujuk apa itu picoin? Berapakah harga untuk penyenaraian? Penggunaan PI, perlombongan dan analisis keselamatan. Apa itu Pinetwork? Projek Pinetwork bermula pada tahun 2019 dan memiliki syiling pi cryptocurrency eksklusifnya. Projek ini bertujuan untuk mewujudkan satu yang semua orang boleh mengambil bahagian

Gelung peristiwa ialah bahagian asas Node.js dan mendayakan pengaturcaraan tak segerak dengan memastikan bahawa utas utama tidak disekat Memahami gelung peristiwa adalah penting untuk membina aplikasi yang cekap. Artikel berikut akan memberi anda pemahaman yang mendalam tentang gelung acara dalam Node.

Sebab mengapa nod tidak boleh menggunakan arahan npm adalah kerana pembolehubah persekitaran tidak dikonfigurasikan dengan betul Penyelesaiannya ialah: 1. Buka "Sistem Sifat"; 2. Cari "Pembolehubah Persekitaran" -> "Pembolehubah Sistem", dan kemudian edit persekitaran. pembolehubah; 3. Cari lokasi folder nodejs;
