


Adakah Node.js benar-benar satu benang? Bagaimana untuk berkomunikasi antara proses?
Artikel ini akan memperkenalkan proses dan urutan kepada anda, membawa anda memahami urutan dalam Node.js, lihat sama ada nod benar-benar satu-benang, proses_kanak-kanak dan modul kluster, dan bercakap secara ringkas tentang lebih lanjut Bagaimana benang berkomunikasi antara satu sama lain.
Proses
Dalam sistem pengendalian, penjelasan proses: Proses ialah program dengan fungsi bebas tertentu dalam data Proses pelaksanaan dinamik pada set ialah unit bebas untuk peruntukan sumber dan penjadualan oleh sistem pengendalian, dan merupakan pembawa untuk aplikasi berjalan.
ialah proses menjalankan aplikasi (konsep dinamik)
ialah unit asas untuk peruntukan sistem dan penjadualan sumber (suatu proses ialah umumnya terdiri daripada atur cara , pengumpulan data dan blok kawalan proses)
Setiap proses mempunyai alamat ruang dan timbunan data sendiri (data tidak dikongsi antara proses dan boleh disampaikan melalui kaedah lain ) Proses umumnya mempunyai lima keadaan: keadaan awal, keadaan pelaksanaan, keadaan menunggu, keadaan sedia dan keadaan penamatan
Benang
Benang ialah. program melaksanakan Proses kawalan berjujukan tunggal ialah unit terkecil aliran pelaksanaan program dan unit asas penjadualan dan penghantaran pemproses.
Unit terkecil penjadualan tugas dan pelaksanaan
Satu laluan pelaksanaan kod dalam satu proses
Perbezaan antara proses dan utas
Benang ialah unit terkecil pelaksanaan program dan proses ialah unit sumber terkecil yang diperuntukkan oleh sistem pengendalian satu atau lebih utas, dan utas ialah kod dalam proses Proses laluan pelaksanaan yang berbeza adalah bebas antara satu sama lain, tetapi ruang memori program kongsi antara utas dalam proses yang sama Pensuisan konteks proses
Proses dalam nod
Nod berbenang tunggal, iaitu, proses hanya membuka satu nod benang. [Pembelajaran yang disyorkan: "tutorial nodejs"] Adakah
benar-benar satu benang?
Walaupun Nod berbenang tunggal, lapisan asasnya berbilang benang. Dalam gelung peristiwa, pustaka libuv mengeluarkan tugasan daripada baris gilir acara dan menugaskannya kepada urutan yang berbeza untuk diproses. Sekarang keadaan perkakasan tidak mundur seperti dahulu Jika hanya satu utas digunakan untuk operasi, sumber akan dibazirkan. Oleh itu, untuk mencapai pemprosesan berbilang proses dan memberikan permainan penuh kepada kelebihan CPU berbilang teras, Node menyediakan modul child_process dan modul kluster.
Modul child_process digunakan untuk memulakan berbilang proses anak, yang menjalankan arahan berbeza atau melaksanakan fail modul node.js dan fail boleh laku
Kluster modul, modul kluster, digunakan untuk memulakan berbilang sub-proses dalam aplikasi Node.js dan menjalankan salinan aplikasi Node.js dalam setiap sub-proses
modul child_process
child_process.spawn(): sesuai untuk mengembalikan sejumlah besar data, seperti pemprosesan imej dan pemprosesan data binari.
child_process.exec(): sesuai untuk jumlah data yang kecil Nilai lalai maxBuffer ialah 200 * 1024. Melebihi nilai lalai ini akan menyebabkan program ranap data terlalu besar, spawn boleh digunakan.
-
child_process.execFile(): serupa dengan child_process.exec(), perbezaannya ialah ia tidak boleh dilaksanakan melalui shell dan tidak menyokong tingkah laku seperti pengalihan I/O dan carian fail
child_process.fork(): Melahirkan proses baharu setiap proses mempunyai contoh V8 sendiri dan sumber Sistem adalah terhad untuk melahirkan terlalu banyak proses Bilangan proses anak yang keluar biasanya ditetapkan mengikut bilangan sistem * teras CPU.
modul kelompok
cluster.fork([env]) Mulakan proses anak dan cipta Nod dalam proses anak Contoh aplikasi .js
atribut isMaster dan atribut isWorker digunakan untuk menentukan sama ada ia berjalan dalam proses utama atau dalam proses anak
-
Atribut Workers digunakan untuk mendapatkan objek pekerja yang berjalan dalam semua sub-proses
Mengembangkan, bagaimanakah beberapa utas berkomunikasi antara satu sama lain?
Komunikasi antara proses
Empat jenis:
-
Penghantaran mesej (saluran paip, FIFO, baris gilir mesej)
Semaphore (muteks, pembolehubah keadaan, kunci baca-tulis)
Memori dikongsi (tanpa nama, dinamakan)
Panggilan prosedur jauh
Komunikasi antara proses bukan sahaja ditemui dalam nod, tetapi juga dalam bahasa lain, ia juga merupakan soalan yang mesti ditanya dalam temu bual.
Banyak kandungan boleh dibincangkan secara mendalam!
Untuk lebih banyak pengetahuan berkaitan pengaturcaraan, sila lawati: Pengenalan kepada Pengaturcaraan! !
Atas ialah kandungan terperinci Adakah Node.js benar-benar satu benang? Bagaimana untuk berkomunikasi antara proses?. 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!

Memilih imej Docker untuk Node mungkin kelihatan seperti perkara remeh, tetapi saiz dan potensi kelemahan imej itu boleh memberi kesan yang ketara pada proses dan keselamatan CI/CD anda. Jadi bagaimana kita memilih imej Node.js Docker yang terbaik?

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.

Node 19 telah dikeluarkan secara rasmi Artikel ini akan memberi anda penjelasan terperinci tentang 6 ciri utama Node.js 19. Saya harap ia akan membantu anda!

Bagaimanakah Node.js melakukan GC (pengumpulan sampah)? Artikel berikut akan membawa anda melaluinya.

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;
