兩個 Node.js 程式如何在h5直播原始碼中實現通訊?
在h5直播原始碼開發中,兩個 Node.js 程式之間如何進行通訊呢?這裡要分兩種場景:
1、不同電腦上的兩個 Node.js 程式間通訊
2、同一臺電腦上兩個 Node.js 程式間通訊
對於第一種場景,h5直播原始碼通常使用 TCP 或 HTTP 進行通訊,而對於第二種場景,又分為兩種子場景:
1、Node.js 程式和自己建立的 Node.js 子程式通訊
2、Node.js 程式和另外不相關的 Node.js 程式通訊
前者可以使用內建的 IPC 通訊通道,後者可以使用自定義管道,接下來進行詳細介紹:
不同電腦上的兩個 Node.js 程式間通訊
要想進行通訊,首先得搞清楚如何標識網路中的程式?h5直播原始碼網路層的 ip 地址可以唯一標識網路中的主機,而h5直播原始碼傳輸層的協議和埠可以唯一標識主機中的應用程式(程式),這樣利用三元組(ip 地址,協議,埠)就可以標識網路的程式了。
使用 TCP 套接字
TCP 套接字(socket)是一種基於 TCP/IP 協議的通訊方式,可以讓h5直播原始碼通過網路連線的計算機上的程式進行通訊。一個作為 server 另一個作為 client,server.js 程式碼如下:
const net = require('net') const server = net.createServer(socket => { console.log('socket connected') socket.on('close', () => console.log('socket disconnected')) socket.on('error', err => console.error(err.message)) socket.on('data', data => { console.log(`receive: ${data}`) socket.write(data) console.log(`send: ${data}`) }) }) server.listen(8888)
client.js 程式碼:
const net = require('net') const client = net.connect(8888, '192.168.10.105') client.on('connect', () => console.log('connected.')) client.on('data', data => console.log(`receive: ${data}`)) client.on('end', () => console.log('disconnected.')) client.on('error', err => console.error(err.message)) setInterval(() => { const msg = 'hello' console.log(`send: ${msg}`) client.write(msg) }, 3000)
執行效果:
$ node server.js client connected receive: hello send: hello $ node client.js connect to server send: hello receive: hello
使用 HTTP 協議因為 HTTP 協議也是基於 TCP 的,所以從h5直播原始碼通訊角度看,這種方式本質上並無區別,只是封裝了上層協議。
server.js 程式碼為:
const http = require('http') http.createServer((req, res) => res.end(req.url)).listen(8888)
client.js 程式碼:
const http = require('http') const options = { hostname: '192.168.10.105', port: 8888, path: '/hello', method: 'GET', } const req = http.request(options, res => { console.log(`statusCode: ${res.statusCode}`) res.on('data', d => process.stdout.write(d)) }) req.on('error', error => console.error(error)) req.end()
執行效果:
$ node server.js url /hello $ node client.js statusCode: 200hello
同一臺電腦上兩個 Node.js 程式間通訊
雖然網路 socket 也可用於同一臺主機的程式間通訊(通過 loopback 地址 127.0.0.1),但是這種方式需要經過網路協議棧、需要打包拆包、計算校驗和、維護序號和應答等,就是為網路通訊設計的,而同一臺電腦上的兩個程式可以有更高效的通訊方式,即 IPC(Inter-Process Communication),在 unix 上具體的實現方式為 unix domain socket,這是h5直播原始碼伺服器端和客戶端之間通過本地開啟的套接字檔案進行通訊的一種方法,與 TCP 通訊不同,h5直播原始碼通訊時指定本地檔案,因此不進行域解析和外部通訊,所以比 TCP 快,在同一臺主機的傳輸速度是 TCP 的兩倍。
使用內建 IPC 通道
如果是跟自己建立的h5直播原始碼子程式通訊,是非常方便的,child_process 模組中的 fork 方法自帶通訊機制,無需關注底層細節,例如父程式 parent.js 程式碼:
const http = require('http') const options = { hostname: '192.168.10.105', port: 8888, path: '/hello', method: 'GET', } const req = http.request(options, res => { console.log(`statusCode: ${res.statusCode}`) res.on('data', d => process.stdout.write(d)) }) req.on('error', error => console.error(error)) req.end()
子程式 child.js 程式碼:
process.on("message", (message) => { console.log("message from parent:", message); }) if (process.send) { setInterval(() => process.send("hello"), 3000) }
執行效果如下:
$ node parent.js message from child: hello message from parent: hi message from child: hello message from parent: hi
使用自定義管道
如果是兩個獨立的 Node.js 程式,如何建立h5直播原始碼通訊通道呢?在 Windows 上可以使用命名管道(Named PIPE),在 unix 上可以使用 unix domain socket,也是一個作為 server,另外一個作為 client,其中 server.js 程式碼如下:
const net = require('net') const fs = require('fs') const pipeFile = process.platform === 'win32' ? '\\\\.\\pipe\\mypip' : '/tmp/unix.sock' const server = net.createServer(connection => { console.log('socket connected.') connection.on('close', () => console.log('disconnected.')) connection.on('data', data => { console.log(`receive: ${data}`) connection.write(data) console.log(`send: ${data}`) }) connection.on('error', err => console.error(err.message)) }) try { fs.unlinkSync(pipeFile) } catch (error) {} server.listen(pipeFile)
client.js 程式碼如下:
const net = require('net') const pipeFile = process.platform === 'win32' ? '\\\\.\\pipe\\mypip' : '/tmp/unix.sock' const client = net.connect(pipeFile) client.on('connect', () => console.log('connected.')) client.on('data', data => console.log(`receive: ${data}`)) client.on('end', () => console.log('disconnected.')) client.on('error', err => console.error(err.message)) setInterval(() => { const msg = 'hello' console.log(`send: ${msg}`) client.write(msg) }, 3000)
執行效果:
$ node server.js socket connected.receive: hello send: hello $ node client.js connected.send: hello receive: hello
以上便是“h5直播原始碼開發,兩個 Node.js 程式如何通訊?”的全部內容,根據實際的開發情況進行分析,選擇最合適的實現方式,才更有利於h5直播原始碼的發展,希望以上內容能對大家有幫助。
本文轉載自網路,轉載僅為分享乾貨知識,如有侵權歡迎聯絡雲豹科技進行刪除處理
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69996194/viewspace-2794964/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 實現手機直播原始碼中兩個執行緒依次執行的相關程式碼原始碼執行緒
- app直播原始碼,Node.js實現密碼雜湊加密APP原始碼Node.js密碼加密
- 兩個視窗如何實現通訊
- 如何在微信小程式中實現音視訊通話微信小程式
- 實現兩個視窗通訊方法之postMessage
- Node.js原始碼解析-Readable實現Node.js原始碼
- 成品直播原始碼推薦,登入和註冊兩個頁面的簡單實現原始碼
- 一對一直播交友原始碼實現即時通訊非常“有一套”原始碼
- 如何在遊戲陪玩app原始碼中實現簡訊驗證碼登入?遊戲APP原始碼
- 相親交友原始碼中,音訊AAC解碼的實現程式碼原始碼音訊
- 兩個Arduino 與兩個MCP2515 CAN模組通訊實現(用到ec11編碼器)UI
- 直播程式原始碼實現直播業務時必不可少的方面原始碼
- 20 行 Python 程式碼實現加密通訊Python加密
- 直播小程式原始碼,小程式生成二維碼 (相容H5、微信小程式)原始碼H5微信小程式
- app直播原始碼,自定義兩種Activity切換動畫實現APP原始碼動畫
- h5直播原始碼流量變現的途徑都有哪些?H5原始碼
- “兩行”程式碼,幫你快速實現FaceTime的新多人視訊通話效果
- 如何實現直播間原始碼重要的簡訊驗證碼功能原始碼
- 如何在直播應用中實現多人KTV?
- 在相親原始碼的多人音視訊聊天中插入現場直播的實現方式原始碼
- 在相親交友原始碼中實現視訊連麥直播需要哪些步驟?原始碼
- 影片直播系統原始碼,非同步處理實現程式碼分析原始碼非同步
- 直播賣貨小程式原始碼中,商品分類頁面是如何實現的原始碼
- 為了直播流暢,實現直播商城原始碼的轉碼原始碼
- 直播電商原始碼,簡述直播的實現原理原始碼
- app直播原始碼如何實現直播間紅包功能APP原始碼
- 【附加題1】通過程式碼實現兩個超大的數字相加的結果?
- Java實現TCP通訊程式JavaTCP
- golang實現子程式通訊Golang
- 直播小程式原始碼,vue實現時間倒數計時原始碼Vue
- 想要實現帶貨直播原始碼秒開?先看看這個原始碼
- 直播原始碼,獲取兩個日期之間的所有日期原始碼
- 視訊直播原始碼,css實現圖片對角邊框線原始碼CSS
- 直播電商原始碼,利用Kotlin+RocketMQ 實現延時訊息原始碼KotlinMQ
- 手機直播原始碼,Android studio 實現簡單的視訊播放原始碼Android
- 線上直播系統原始碼,Node.js中使用Koa實現上傳圖片功能原始碼Node.js
- 通過 App Groups 實現程式間通訊APP
- H5直播原始碼具有怎樣的優勢?H5原始碼