Rumah hujung hadapan web tutorial js Tutorial pengenalan minimalis Nodejs (3): Process_node.js

Tutorial pengenalan minimalis Nodejs (3): Process_node.js

May 16, 2016 pm 04:32 PM
nodejs Tutorial Bermula proses

Walaupun Node mempunyai berbilang utas, JavaScript yang dijalankan pada v8 adalah satu utas. Modul child_process Node digunakan untuk mencipta proses anak dan kami boleh menggunakan sepenuhnya CPU melalui proses anak. Contoh:

Salin kod Kod adalah seperti berikut:

var fork = memerlukan('child_process').fork;
// Dapatkan bilangan CPU mesin semasa
var cpus = memerlukan('os').cpus();
untuk (var i = 0; i < cpus.length; i ) {
// Jana proses baharu
Fork('./worker.js');
}

Berikut ialah beberapa kaedah penciptaan proses termasuk garpu:

1.spawn(command, [args], [options]), memulakan proses baharu untuk melaksanakan arahan arahan, args ialah parameter baris arahan
2.exec(arahan, [pilihan], panggil balik), memulakan proses baharu untuk melaksanakan arahan arahan, panggil balik digunakan untuk mendapatkan input standard, output standard dan maklumat ralat apabila proses tamat
3.execFile(fail, [args], [options], [panggilan balik]), memulakan proses baharu untuk melaksanakan fail fail boleh laku, panggil balik digunakan untuk mendapatkan input standard, output standard dan maklumat ralat apabila proses tamat
4.fork(modulePath, [args], [options]), memulakan proses baharu untuk melaksanakan modul fail JavaScript dan proses anak Node dibuat pada masa ini

Komunikasi antara proses nod

Proses Ibu Bapa

Salin kod Kod adalah seperti berikut:

// parent.js
var fork = memerlukan('child_process').fork;
// fork mengembalikan objek proses anak n
var n = fork('./child.js');
// Kendalikan mesej acara
n.on('message', function(m) {
// Terima mesej yang dihantar oleh proses anak
console.log('dapat mesej: ' m);
});

//Hantar mesej kepada proses anak
n.send({hello: 'world'});

Proses kanak-kanak

Salin kod Kod adalah seperti berikut:

// child.js
// Kendalikan mesej acara
process.on('message', function(m) {
console.log('dapat mesej: ' m);
});

// Terdapat kaedah hantar dalam proses, yang digunakan untuk menghantar mesej kepada proses induk
process.send({foo: 'bar'});

Perlu diingatkan bahawa kaedah penghantaran di sini adalah segerak, jadi tidak disyorkan untuk menghantar sejumlah besar data (anda boleh menggunakan paip sebaliknya, lihat untuk butiran: http://nodejs.org/api/ semua. html#process_child_process_spawn_command_args_options).
Dalam kes khas, jika nilai atribut cmd dalam mesej mengandungi awalan NODE_ (contohnya: {cmd: 'NODE_foo'} mesej), maka mesej ini tidak akan diserahkan kepada acara mesej (tetapi acara internalMessage), dan mereka digunakan secara dalaman oleh Node.

Prototaip

kaedah hantar ialah:

Salin kod Kod adalah seperti berikut:

hantar(mesej, [sendHandle])

Di sini, sendHandle(handle) boleh digunakan untuk menghantar:

1.net.Soket atau paip TCP C asli, asli
2.net.Server, pelayan TCP
3.net.Soket, soket TCP
4.dgram.Soket C UDP asli, asli
5.dgram.Soket, soket UDP

Apabila hantar menghantar sendHandle, ia sebenarnya tidak (dan tidak boleh) menghantar objek JavaScript secara langsung, tetapi menghantar deskriptor fail (akhirnya dihantar sebagai rentetan JSON Proses lain boleh menggunakan deskriptor fail ini untuk memulihkan objek yang sepadan).

Sekarang lihat contoh:

Proses Ibu Bapa

Salin kod Kod adalah seperti berikut:

// parent.js
var fork = memerlukan('child_process').fork;

var n = fork('./child.js');

pelayan var = memerlukan('net').createServer();
server.listen(7000, function() {
//Hantar pelayan TCP ke proses anak
n.send('server', server);
}).on('sambungan', function() {
console.log('sambungan - ibu bapa');
});

Proses kanak-kanak

Salin kod Kod adalah seperti berikut:

process.on('message', function(m, h) {
Jika (m === 'pelayan') {
          h.on('connection', function() {
console.log('sambungan - anak');
});
}
});

Akses program ini melalui port 7000, dan output mungkin sambungan – ibu bapa atau sambungan – anak. Di sini proses anak dan proses induk sedang mendengar pada port 7000 pada masa yang sama. Secara umumnya, berbilang proses mendengar port yang sama akan menyebabkan pengecualian EADDRINUSE Dalam kes ini, dua proses berbeza menggunakan deskriptor fail yang sama, dan lapisan bawah Node menetapkan pilihan SO_REUSEADDR pada soket apabila mendengar pada port membenarkan soket ini digunakan semula antara proses yang berbeza. Apabila berbilang proses mendengar port yang sama, deskriptor fail hanya boleh digunakan oleh satu proses pada masa yang sama, dan penggunaan soket oleh proses ini adalah preemptive.

modul kluster

Modul kluster telah ditambahkan dalam Node v0.8 Melalui modul kluster, anda boleh membina sekumpulan proses mendengar port yang sama pada mesin fizikal. Contoh:

Salin kod Kod adalah seperti berikut:

var cluster = memerlukan('cluster');
var http = memerlukan('http');
var numCPUs = memerlukan('os').cpus().panjang;

// Semak sama ada proses itu adalah proses induk
jika (cluster.isMaster) {
untuk (var i = 0; i < numCPUs; i)
// Hasilkan proses pekerja baharu (hanya proses induk boleh dipanggil)
        cluster.fork();

cluster.on('keluar', fungsi(pekerja, kod, isyarat) {
console.log('pekerja ' pekerja.proses.pid ' meninggal dunia');
});
} lain {
http.createServer(function(req, res) {
           res.writeHead(200);
          res.end('hello worldn');
}).dengar(8000);
}

Kami memanggil kaedah mendengar dalam proses pekerja, dan permintaan mendengar akan dihantar kepada proses induk. Jika proses induk sudah mempunyai pelayan mendengar yang memenuhi keperluan proses pekerja, maka pemegang pelayan ini akan diserahkan kepada pekerja Jika ia tidak wujud, proses induk akan mencipta satu dan kemudian menyerahkan pemegang kepada proses pekerja.

Dokumentasi yang lebih terperinci tentang kelompok: http://www.nodejs.org/api/cluster.html

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)
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
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)

Adakah nodejs rangka kerja bahagian belakang? Adakah nodejs rangka kerja bahagian belakang? Apr 21, 2024 am 05:09 AM

Node.js boleh digunakan sebagai rangka kerja bahagian belakang kerana ia menawarkan ciri seperti prestasi tinggi, kebolehskalaan, sokongan merentas platform, ekosistem yang kaya dan kemudahan pembangunan.

Bagaimana untuk menyambungkan nodejs ke pangkalan data mysql Bagaimana untuk menyambungkan nodejs ke pangkalan data mysql Apr 21, 2024 am 06:13 AM

Untuk menyambung ke pangkalan data MySQL, anda perlu mengikuti langkah berikut: Pasang pemacu mysql2. Gunakan mysql2.createConnection() untuk mencipta objek sambungan yang mengandungi alamat hos, port, nama pengguna, kata laluan dan nama pangkalan data. Gunakan connection.query() untuk melaksanakan pertanyaan. Akhir sekali gunakan connection.end() untuk menamatkan sambungan.

Apakah perbezaan antara fail npm dan npm.cmd dalam direktori pemasangan nodejs? Apakah perbezaan antara fail npm dan npm.cmd dalam direktori pemasangan nodejs? Apr 21, 2024 am 05:18 AM

Terdapat dua fail berkaitan npm dalam direktori pemasangan Node.js: npm dan npm.cmd Perbezaannya adalah seperti berikut: sambungan berbeza: npm ialah fail boleh laku dan npm.cmd ialah pintasan tetingkap arahan. Pengguna Windows: npm.cmd boleh digunakan daripada command prompt, npm hanya boleh dijalankan dari baris arahan. Keserasian: npm.cmd adalah khusus untuk sistem Windows, npm tersedia merentas platform. Cadangan penggunaan: Pengguna Windows menggunakan npm.cmd, sistem pengendalian lain menggunakan npm.

Apakah pembolehubah global dalam nodejs Apakah pembolehubah global dalam nodejs Apr 21, 2024 am 04:54 AM

Pembolehubah global berikut wujud dalam Node.js: Objek global: modul Teras global: proses, konsol, memerlukan pembolehubah persekitaran Runtime: __dirname, __filename, __line, __column Constants: undefined, null, NaN, Infinity, -Infinity

Adakah terdapat perbezaan besar antara nodejs dan java? Adakah terdapat perbezaan besar antara nodejs dan java? Apr 21, 2024 am 06:12 AM

Perbezaan utama antara Node.js dan Java ialah reka bentuk dan ciri: Didorong peristiwa vs. didorong benang: Node.js dipacu peristiwa dan Java dipacu benang. Satu-benang vs. berbilang benang: Node.js menggunakan gelung acara satu-benang dan Java menggunakan seni bina berbilang benang. Persekitaran masa jalan: Node.js berjalan pada enjin JavaScript V8, manakala Java berjalan pada JVM. Sintaks: Node.js menggunakan sintaks JavaScript, manakala Java menggunakan sintaks Java. Tujuan: Node.js sesuai untuk tugas intensif I/O, manakala Java sesuai untuk aplikasi perusahaan besar.

Adakah nodejs bahasa pembangunan bahagian belakang? Adakah nodejs bahasa pembangunan bahagian belakang? Apr 21, 2024 am 05:09 AM

Ya, Node.js ialah bahasa pembangunan bahagian belakang. Ia digunakan untuk pembangunan bahagian belakang, termasuk mengendalikan logik perniagaan sebelah pelayan, mengurus sambungan pangkalan data dan menyediakan API.

Bagaimana untuk menggunakan projek nodejs ke pelayan Bagaimana untuk menggunakan projek nodejs ke pelayan Apr 21, 2024 am 04:40 AM

Langkah-langkah penggunaan pelayan untuk projek Node.js: Sediakan persekitaran penggunaan: dapatkan akses pelayan, pasang Node.js, sediakan repositori Git. Bina aplikasi: Gunakan npm run build untuk menjana kod dan kebergantungan yang boleh digunakan. Muat naik kod ke pelayan: melalui Git atau Protokol Pemindahan Fail. Pasang kebergantungan: SSH ke dalam pelayan dan gunakan pemasangan npm untuk memasang kebergantungan aplikasi. Mulakan aplikasi: Gunakan arahan seperti node index.js untuk memulakan aplikasi, atau gunakan pengurus proses seperti pm2. Konfigurasikan proksi terbalik (pilihan): Gunakan proksi terbalik seperti Nginx atau Apache untuk menghalakan trafik ke aplikasi anda

Mana satu untuk dipilih antara nodejs dan java? Mana satu untuk dipilih antara nodejs dan java? Apr 21, 2024 am 04:40 AM

Node.js dan Java masing-masing mempunyai kebaikan dan keburukan dalam pembangunan web, dan pilihan bergantung pada keperluan projek. Node.js cemerlang dalam aplikasi masa nyata, pembangunan pesat dan seni bina perkhidmatan mikro, manakala Java cemerlang dalam sokongan, prestasi dan keselamatan gred perusahaan.

See all articles