Rumah >hujung hadapan web >tutorial js >Apakah sumber tak segerak? Analisis ringkas kaedah Node untuk merealisasikan perkongsian konteks sumber tak segerak

Apakah sumber tak segerak? Analisis ringkas kaedah Node untuk merealisasikan perkongsian konteks sumber tak segerak

青灯夜游
青灯夜游ke hadapan
2022-05-31 12:56:192800semak imbas

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.

Apakah sumber tak segerak? Analisis ringkas kaedah Node untuk merealisasikan perkongsian konteks sumber tak segerak

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 oleh

Node.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:

run(store, callback[, ...args]) Gunakan run untuk menentukan stor konteks dan fungsi panggil balik yang berkesan diperolehi dalam fungsi panggil balik.
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.
Berikut ialah contoh untuk menunjukkan cara menggunakan AsyncLocalStorage untuk melaksanakan perkongsian konteks sumber tak segerak:

Output: Apakah sumber tak segerak? Analisis ringkas kaedah Node untuk merealisasikan perkongsian konteks sumber tak segerak

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 oleh

Kuzzle

, 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!

Kenyataan:
Artikel ini dikembalikan pada:juejin.cn. Jika ada pelanggaran, sila hubungi admin@php.cn Padam