Rumah  >  Artikel  >  hujung hadapan web  >  Adakah Node.js benar-benar satu benang? Bagaimana untuk berkomunikasi antara proses?

Adakah Node.js benar-benar satu benang? Bagaimana untuk berkomunikasi antara proses?

青灯夜游
青灯夜游ke hadapan
2021-08-02 18:44:082457semak imbas

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.

Adakah Node.js benar-benar satu benang? Bagaimana untuk berkomunikasi antara proses?

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!

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