Tutorial pengenalan minimalis Nodejs (3): Process_node.js
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:
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
// 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
// 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.
kaedah hantar ialah:
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
// 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
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:
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

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



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.

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.

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.

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

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.

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.

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

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.
