Jadual Kandungan
Proses
Benang
Proses dalam nod
modul child_process
modul kelompok
Komunikasi antara proses
Rumah hujung hadapan web tutorial js Adakah Node.js benar-benar satu benang? Bagaimana untuk berkomunikasi antara proses?

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

Aug 02, 2021 pm 06:44 PM
node.js benang tunggal

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 Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Artikel tentang kawalan memori dalam Node Artikel tentang kawalan memori dalam Node Apr 26, 2023 pm 05:37 PM

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

Penjelasan grafik terperinci tentang memori dan GC enjin Node V8 Penjelasan grafik terperinci tentang memori dan GC enjin Node V8 Mar 29, 2023 pm 06:02 PM

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

Mari kita bincangkan tentang cara memilih imej Node.js Docker terbaik? Mari kita bincangkan tentang cara memilih imej Node.js Docker terbaik? Dec 13, 2022 pm 08:00 PM

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?

Mari bercakap secara mendalam tentang modul Fail dalam Node Mari bercakap secara mendalam tentang modul Fail dalam Node Apr 24, 2023 pm 05:49 PM

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.js 19 dikeluarkan secara rasmi, mari bercakap tentang 6 ciri utamanya! Node.js 19 dikeluarkan secara rasmi, mari bercakap tentang 6 ciri utamanya! Nov 16, 2022 pm 08:34 PM

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!

Mari bercakap tentang mekanisme GC (pengumpulan sampah) dalam Node.js Mari bercakap tentang mekanisme GC (pengumpulan sampah) dalam Node.js Nov 29, 2022 pm 08:44 PM

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

Mari kita bincangkan tentang gelung acara dalam Node Mari kita bincangkan tentang gelung acara dalam Node Apr 11, 2023 pm 07:08 PM

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.

Apakah yang perlu saya lakukan jika nod tidak boleh menggunakan arahan npm? Apakah yang perlu saya lakukan jika nod tidak boleh menggunakan arahan npm? Feb 08, 2023 am 10:09 AM

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;

See all articles