


Bekerja dengan WebSocket dan Komunikasi Masa Nyata dalam Node.js
Dalam aplikasi moden, komunikasi masa nyata adalah penting, terutamanya untuk ciri seperti sembang langsung, pemberitahuan dan alatan kerjasama. WebSocket ialah protokol yang membolehkan komunikasi dua arah antara klien dan pelayan melalui sambungan tunggal yang tahan lama. Artikel ini merangkumi WebSocket, pelaksanaannya dalam Node.js dan peranan Socket.IO, perpustakaan popular yang memudahkan penggunaan WebSocket dalam aplikasi masa nyata.
WebSocket: Apa, Mengapa, dan Bagaimana?
WebSocket ialah protokol yang mengekalkan sambungan berterusan, membenarkan pertukaran data tanpa kitaran permintaan-tindak balas yang berterusan HTTP. Beberapa kes penggunaan termasuk:
- Aplikasi Pemesejan langsung (cth., bilik sembang)
- Permainan dalam talian memerlukan kemas kini masa nyata
- Pemberitahuan untuk acara dalam aplikasi media sosial
- Alat kolaboratif (cth., Dokumen Google)
Bagaimana WebSocket Berfungsi
- Pelanggan mewujudkan sambungan HTTP dengan pelayan.
- Pelayan menaik taraf sambungan ini kepada protokol WebSocket.
- Kedua-dua pelanggan dan pelayan kemudiannya boleh menghantar dan menerima mesej dalam masa nyata melalui sambungan berterusan ini.
Melaksanakan WebSocket dalam Node.j
Pelayan WebSocket Asas dengan ws
Mari bina pelayan WebSocket mudah menggunakan pakej ws.
Langkah 1: Pasang ws:
npm install ws
Langkah 2: Buat pelayan WebSocket:
const WebSocket = require('ws'); const server = new WebSocket.Server({ port: 8080 }); server.on('connection', (socket) => { console.log('Client connected'); // Listening for messages from the client socket.on('message', (message) => { console.log(`Received message: ${message}`); // Echo message back to client socket.send(`Server: ${message}`); }); // Handling connection close socket.on('close', () => { console.log('Client disconnected'); }); }); console.log('WebSocket server is running on ws://localhost:8080');
Langkah 3: Menyambung dari sisi pelanggan:
<script> const socket = new WebSocket('ws://localhost:8080'); socket.onopen = () => { console.log('Connected to server'); socket.send('Hello Server!'); }; socket.onmessage = (event) => { console.log(`Received from server: ${event.data}`); }; </script>
Memperkenalkan Socket.IO: Pengurusan WebSocket Ringkas
Socket.IO ialah perpustakaan yang memudahkan komunikasi masa nyata dan menambahkan ciri seperti penyambungan semula automatik dan penyiaran.
Pemasangan Socket.IO
npm install socket.io
Membina Aplikasi Sembang Masa Nyata dengan Socket.IO
Pelaksanaan Bahagian Pelayan:
const express = require('express'); const http = require('http'); const { Server } = require('socket.io'); const app = express(); const server = http.createServer(app); const io = new Server(server); io.on('connection', (socket) => { console.log('A user connected'); socket.on('chat message', (msg) => { // Broadcast message to all connected clients io.emit('chat message', msg); }); socket.on('disconnect', () => { console.log('User disconnected'); }); }); server.listen(3000, () => { console.log('Server is listening on http://localhost:3000'); });
Pelaksanaan Sebelah Pelanggan:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Real-Time Chat</title> </head> <body> <h1>Chat Room</h1> <input> <h2> Node.js Streams: Efficient Data Handling </h2> <p>Node.js streams provide a way to process data piece by piece, which is particularly useful for handling large files.</p> <h3> Types of Streams </h3> <ol> <li> <strong>Readable</strong>: For reading data from a source.</li> <li> <strong>Writable</strong>: For writing data to a destination.</li> <li> <strong>Duplex</strong>: For both reading and writing.</li> <li> <strong>Transform</strong>: For modifying or transforming data as it’s read or written.</li> </ol> <h3> Example: Reading a Large File with Streams </h3> <pre class="brush:php;toolbar:false">const fs = require('fs'); const readStream = fs.createReadStream('largefile.txt', { encoding: 'utf8' }); readStream.on('data', (chunk) => { console.log('New chunk received:', chunk); }); readStream.on('end', () => { console.log('File reading completed'); });
Menskalakan Aplikasi Node.js
Menskalakan aplikasi Node.js memastikan ia boleh mengendalikan beban yang meningkat dengan menambahkan lebih banyak sumber.
Penskalaan Mendatar
- Letakkan berbilang contoh permohonan dan permintaan imbangan beban.
Penskalaan Menegak
- Tingkatkan kuasa pelayan (CPU, memori) untuk mengendalikan lebih banyak permintaan.
NGINX: Pengimbangan Beban dan Penyajian Kandungan Statik
NGINX ialah pelayan web yang sering digunakan untuk pengimbangan beban, caching dan menyajikan kandungan statik.
Contoh: Melayan Fail Statik dengan NGINX
- Pasang NGINX
npm install ws
- Konfigurasikan NGINX
Edit /etc/nginx/sites-available/default:
const WebSocket = require('ws'); const server = new WebSocket.Server({ port: 8080 }); server.on('connection', (socket) => { console.log('Client connected'); // Listening for messages from the client socket.on('message', (message) => { console.log(`Received message: ${message}`); // Echo message back to client socket.send(`Server: ${message}`); }); // Handling connection close socket.on('close', () => { console.log('Client disconnected'); }); }); console.log('WebSocket server is running on ws://localhost:8080');
- Mulakan NGINX
<script> const socket = new WebSocket('ws://localhost:8080'); socket.onopen = () => { console.log('Connected to server'); socket.send('Hello Server!'); }; socket.onmessage = (event) => { console.log(`Received from server: ${event.data}`); }; </script>
SSL dan Keselamatan
SSL menyulitkan data antara klien dan pelayan, menambah lapisan keselamatan. Untuk menyediakan SSL:
- Jana sijil SSL (atau dapatkan sijil daripada pembekal).
- Konfigurasikan NGINX untuk menggunakan SSL:
npm install socket.io
Kesimpulan
Artikel ini telah meneroka keperluan komunikasi masa nyata, pengendalian data yang cekap, penskalaan dan mendapatkan aplikasi Node.js untuk penggunaan peringkat pengeluaran. Strim WebSockets, Socket.IO, NGINX dan Node.js ialah alatan berkuasa yang meningkatkan interaktiviti aplikasi, pengurusan data dan keselamatan untuk pengalaman dan kebolehskalaan pengguna yang lebih baik.
Atas ialah kandungan terperinci Bekerja dengan WebSocket dan Komunikasi Masa Nyata dalam Node.js. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

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)

Skop JavaScript menentukan skop kebolehcapaian pembolehubah, yang dibahagikan kepada skop global, fungsi dan tahap blok; Konteks menentukan arah ini dan bergantung kepada kaedah panggilan fungsi. 1. Skop termasuk skop global (boleh diakses di mana sahaja), skop fungsi (hanya sah dalam fungsi), dan skop peringkat blok (biarkan dan const sah dalam {}). 2. Konteks pelaksanaan mengandungi objek pembolehubah, rantaian skop dan nilai -nilai ini. Ini menunjukkan kepada global atau tidak ditentukan dalam fungsi biasa, kaedah panggilan kaedah ke objek panggilan, pembina menunjuk ke objek baru, dan juga boleh ditentukan secara jelas oleh panggilan/memohon/mengikat. 3. Penutupan merujuk kepada fungsi mengakses dan mengingati pembolehubah skop luaran. Mereka sering digunakan untuk enkapsulasi dan cache, tetapi boleh menyebabkan

Terdapat dua kaedah teras untuk mendapatkan nilai butang radio yang dipilih. 1. Gunakan QuerySelector untuk mendapatkan item yang dipilih secara langsung, dan gunakan input [NAME = "NAMA-NAMA ANDA"]: Pemilih yang diperiksa untuk mendapatkan elemen yang dipilih dan membaca atribut nilainya. Ia sesuai untuk pelayar moden dan mempunyai kod ringkas; 2. Gunakan Document.GetElementsByName untuk melintasi dan mencari radio yang diperiksa pertama melalui nodelist gelung dan mendapatkan nilainya, yang sesuai untuk senario yang serasi dengan pelayar lama atau memerlukan kawalan manual proses; Di samping itu, anda perlu memberi perhatian kepada ejaan atribut nama, mengendalikan situasi yang tidak dipilih, dan pemuatan kandungan dinamik

Untuk menggunakan JavaScript untuk membuat iframe kotak pasir yang selamat, mula-mula gunakan atribut kotak pasir HTML untuk mengehadkan tingkah laku iframe, seperti melarang pelaksanaan skrip, tingkap pop timbul dan penyerahan bentuk; kedua, dengan menambah token tertentu seperti skrip membenarkan untuk melegakan keizinan seperti yang diperlukan; kemudian menggabungkan postmessage () untuk mencapai komunikasi silang domain yang selamat, sambil mengesahkan sumber mesej dan data yang ketat; Akhirnya elakkan kesilapan konfigurasi biasa, seperti tidak mengesahkan sumber, tidak menubuhkan CSP, dan lain -lain, dan melakukan ujian keselamatan sebelum pergi dalam talian.

COMPOSISAPI dalam VUE3 lebih sesuai untuk logik dan jenis derivasi yang kompleks, dan OptionsAPI sesuai untuk senario dan pemula yang mudah; 1. Optionsapi menganjurkan kod mengikut pilihan seperti data dan kaedah, dan mempunyai struktur yang jelas tetapi komponen kompleks dipecah -pecah; 2. CompositionAPI menggunakan persediaan untuk menumpukan logik yang berkaitan, yang kondusif untuk penyelenggaraan dan penggunaan semula; 3. Compositionapi menyedari penggunaan semula logik bebas konflik dan parameternya melalui fungsi kompos yang lebih baik daripada Mixin; 4. CompositionAPI mempunyai sokongan yang lebih baik untuk typescript dan derivasi jenis yang lebih tepat; 5. Tidak terdapat perbezaan yang signifikan dalam jumlah prestasi dan pembungkusan kedua -duanya; 6.

Terdapat perbezaan penting antara pekerja web JavaScript dan Javathreads dalam pemprosesan serentak. 1. JavaScript mengamalkan model tunggal-thread. WebWorkers adalah benang bebas yang disediakan oleh penyemak imbas. Ia sesuai untuk melaksanakan tugas-tugas yang memakan masa yang tidak menghalang UI, tetapi tidak dapat mengendalikan DOM; 2. Java menyokong multithreading sebenar dari tahap bahasa, yang dibuat melalui kelas thread, sesuai untuk logik serentak dan pemprosesan sisi serentak; 3. WebWorkers menggunakan postmessage () untuk berkomunikasi dengan benang utama, yang sangat selamat dan terpencil; Benang Java boleh berkongsi ingatan, jadi isu penyegerakan perlu diberi perhatian; 4. Pekerja web lebih sesuai untuk pengkomputeran selari depan, seperti pemprosesan imej, dan

Debugging Aplikasi JavaScript kompleks memerlukan alat penggunaan sistematik. 1. Tetapkan titik putus dan titik putus bersyarat untuk memintas proses yang mencurigakan, seperti sebelum masuk fungsi, gelung, panggilan balik asynchronous dan penapis mengikut keadaan; 2. Membolehkan fungsi Blackboxing untuk menyekat gangguan perpustakaan pihak ketiga; 3. Gunakan pernyataan debugger untuk mengawal kemasukan debug berdasarkan penghakiman alam sekitar; 4. Jejak pautan panggilan melalui CallStack, menganalisis laluan pelaksanaan dan status berubah -ubah, dengan itu dengan cekap mencari punca utama masalah.

Pemutus jenis adalah tingkah laku secara automatik menukar satu jenis nilai kepada jenis lain dalam JavaScript. Senario biasa termasuk: 1. Apabila menggunakan pengendali, jika satu sisi adalah rentetan, sisi lain juga akan ditukar kepada rentetan, seperti '5' 5. Hasilnya ialah "55"; 2. 3. Null mengambil bahagian dalam operasi berangka dan akan ditukar kepada 0, dan undefined akan ditukar kepada NAN; 4. Masalah yang disebabkan oleh penukaran tersirat boleh dielakkan melalui fungsi penukaran eksplisit seperti nombor (), rentetan (), dan boolean (). Menguasai peraturan ini membantu

Membina sistem reka bentuk JavaScript memerlukan bermula dari keperluan sebenar dan secara beransur -ansur memperbaikinya. 1. Abstraksi komponen harus "cukup tetapi tidak berlebihan". Pertama, merangkumi komponen biasa dan sifat asas, seperti butang pembolehubah dan kurang upaya, dan kemudian mengembangkan permintaan; 2. Pengurusan gaya harus bersatu dan boleh diperpanjang, menggunakan skema CSS-in-JS, pembolehubah tema dan spesifikasi penamaan bersatu, seperti BEM atau cssmodul; 3. Dokumen dan contoh adalah kunci, dan menggunakan buku cerita untuk menyediakan persembahan visual, meliputi penggunaan, status, jadual prop dan contoh senario sebenar; 4. Sistem reka bentuk memerlukan mekanisme kawalan dan kolaborasi versi, dan memastikan penyelenggaraan berterusan melalui pelepasan NPM, proses kemas kini PR dan penyegerakan alat reka bentuk.
