成人无码视频,亚洲精品久久久久av无码,午夜精品久久久久久毛片,亚洲 中文字幕 日韩 无码

資訊專欄INFORMATION COLUMN

mosquitto 與 websocket 的結合

joy968 / 1443人閱讀

摘要:前言作為一個消息代理客戶端與服務端的通信時基于協(xié)議的而現(xiàn)在的主流應用時呈現(xiàn)在瀏覽器中這意味著用戶與服務端只能通過或者這類瀏覽器能理解的協(xié)議傳輸所以后端還要建立一個代理層將協(xié)議傳輸?shù)膬热萁馕鲆幌乱詤f(xié)議發(fā)送到最后再由發(fā)送到硬件端在瀏覽器支持的協(xié)

前言

mosquitto 作為一個消息代理, 客戶端與 mosquitto 服務端的通信時基于 MQTT 協(xié)議的, 而現(xiàn)在的主流 web 應用時呈現(xiàn)在瀏覽器中, 這意味著用戶與服務端只能通過 HTTP 或者 HTTPS 這類瀏覽器能理解的協(xié)議傳輸, 所以后端還要建立一個代理層, 將 HTTP 協(xié)議傳輸?shù)膬热萁馕鲆幌乱?MQTT 協(xié)議發(fā)送到 mosquitto, 最后再由 mosquitto 發(fā)送到硬件端.

在瀏覽器支持的協(xié)議中, 還有一個適用于長連接的 WS 協(xié)議, 參考: 瀏覽器中常見網(wǎng)絡協(xié)議介紹. 如果客戶端直接通過 websocket 連接到 mosquitto 端, 那么就不需要中間的后端代理層. 后端只需要一個推送服務和控制系統(tǒng)就可以實現(xiàn)對客戶端的監(jiān)聽, 控制, 推送(當然, 如果業(yè)務量巨大, 業(yè)務邏輯復雜, 代理層還是有必要的, 因為這樣不但可以為 mosquitto 過濾一些不必要的業(yè)務, 而且可以做一些數(shù)據(jù)統(tǒng)計, 設計事件鉤子).

在編譯 mosquitto 和它的驗證插件 mosquitto-auth-plug 的時候, 我注意到 mosquitto 有一個監(jiān)聽的 9001 端口, 事后查了一下, 發(fā)現(xiàn) mosquitto 開放的這個端口是支持直接與客戶端進行 websocket 通信的.

啟用 mosquitto websocket 模式

其實純粹的 MQTT 服務器是沒有這個功能的, mosquitto 需要在編譯的時候設置 configure.mk

WITH_WEBSOCKETS := yes

所幸的是, eclipse 官方的 docker 鏡像 已經(jīng)支持了 websocket 通信方式. 只需要在 mosquitto.conf 中啟用:

port 1883
listener 9001
protocol websockets
使用 paho-mqtt.js 通過 websocket 與 mosquitto 通信

eclipse 提供了用于 瀏覽器客戶端利用 javascript 和 mosquitto 進行 websocket 通信的 paho-mqtt.js, 這是這個 js 庫的文檔: Paho.MQTT DOC.

客戶端與服務端的雙通道通信

我們假設有客戶端用戶為 client, 服務端用戶為 server. 為他們分配的主題與權限為:

 id | username |      topic         | rw 
----+----------+--------------------+----
  1 | client   | /p/client/upload   |  2
  2 | server   | /p/client/upload   |  2
  3 | client   | /p/client/download |  1
  4 | server   | /p/client/download |  2

那么 server 和 client 均可以在 /p/client/upload 讀寫. 我們約定只有 client 在 /p/client/upload 寫, server 只讀 /p/client/upload, 這個 topic 是用于 client 向 server 發(fā)送消息.

對于 topic /p/client/download, server 可讀可寫, client 只讀, 這個 topic 是用于 client 接受 server 向下推送的消息, 具體的邏輯如下:

注意這里的 client 是對 /p/client/upload 具有可讀可寫權限的, 意味者它可以讀取來自 /p/client/upload 的信息, 但是實際上這里沒有人往這個主題發(fā)布消息(除非 client 自己往這里發(fā)消息), 所以 client 擁有可讀權限也沒有關系.

客戶端的 javascript 通信例子

建議看一下這篇文章: Using MQTT Over WebSockets with Mosquitto, 它比較詳細地介紹了客戶端通過 websocket 于 mosquitto 服務器通信的方式.
比如對于 client.html:
先引入 paho-mqtt.js, 這里我們先用 cloudflare.com CDN上的這段 js:


下面是創(chuàng)建客戶端 websocket 的例子:

var mqtt;
var host = "mosquitto";
var port = 9001;

// onConnect 事件
function onConnect() {
    console.log("connected.");
    var raw_message = "Hello World!";
    message = new Paho.MQTT.Message(raw_message);
    message.destinationName = "/p/client/upload";
    console.log("sending message: " + raw_message );
    mqtt.send(message);

    // 訂閱 download topic
    var subOptions = {
        qos: 1,
        onSuccess: onSubscribe
    };
    mqtt.subscribe("/p/client/download", subOptions);
}

// 訂閱主題成功事件
function onSubscribe(context) {
    console.log("subscribe success");
    console.log(context);
}

// 連接失敗事件
function onFailure(message) {
    console.log("connect failed.");
}

// onMessageArrived 事件
function onMessageArrived(message) {
    console.log("new message arrived...");
    console.log(message.payloadString);
}


// 建立 MQTT websocket 連接
function MQTTconnect() {
    console.log("connecting to " + host + ":" + port);
    mqtt = new Paho.MQTT.Client(host, port, "clientid");
    var options = {
        timeout: 3,
        onSuccess: onConnect,
        onFailure: onFailure,
        userName: "client",
        password: "123456",
        mqttVersion: 4
    };
    mqtt.onMessageArrived = onMessageArrived;
    mqtt.connect(options);
}

這里我們利用 paho-mqtt.js 新建了一個 mqtt, 然后綁定 onSuccess(連接成功), onFailure(連接失敗) onMessageArrived(消息到來)等事件, 之后用 options 里的配置連接到遠程的 mosquitto 服務器. 連接成功后, client 向 server 發(fā)送一條消息到 /p/client/upload topic, 通知服務端已經(jīng)建立連接. 發(fā)送之后 mqtt 又訂閱 /p/client/download, 準備接受來自服務端的信息.

比如, 服務端可以這樣向客戶端推送消息:

import paho.mqtt.publish as publish
import time

HOST = "mosquitto"
PORT = 1883


if __name__ == "__main__":
    client_id = time.strftime("%Y%m%d%H%M%S", time.localtime(time.time()))
    publish.single(
        "/p/client/download", "hello mqtt", qos=2, hostname=HOST, port=PORT,
        client_id=client_id, auth={"username": "server", "password": "123456"})

這就是基于雙通道的服務端于客戶端通信

客戶端與服務端的單通道通信

單通道通信原理類似, 但是由于客戶端可能有多臺設備, 比如手機端, 微信小程序端, PC 端. 那么身份的驗證不能直接由 mosquitto 確定, 應該在消息體內確定. 比如我們用 json 作為消息的承載方式. 消息體可以這樣:

{
    "timestamp": "1539141568",
    "client_id": "1001001",
    "message_type": "ping",
    "data": {"detail": "content"},
    "token": "auth_token"
}

這里應該按照具體的業(yè)務需求進行鑒權設計.

文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://m.hztianpu.com/yun/98221.html

相關文章

  • mosquitto websocket 結合

    摘要:前言作為一個消息代理客戶端與服務端的通信時基于協(xié)議的而現(xiàn)在的主流應用時呈現(xiàn)在瀏覽器中這意味著用戶與服務端只能通過或者這類瀏覽器能理解的協(xié)議傳輸所以后端還要建立一個代理層將協(xié)議傳輸?shù)膬热萁馕鲆幌乱詤f(xié)議發(fā)送到最后再由發(fā)送到硬件端在瀏覽器支持的協(xié) 前言 mosquitto 作為一個消息代理, 客戶端與 mosquitto 服務端的通信時基于 MQTT 協(xié)議的, 而現(xiàn)在的主流 web 應用時呈...

    tomener 評論0 收藏0
  • 基于MQTT物聯(lián)網(wǎng)云測量解決方案

    摘要:本文是其中的一個解決方案。地址客戶端服務端前端網(wǎng)頁介紹,消息隊列遙測傳輸是開發(fā)的一個即時通訊協(xié)議,有可能成為物聯(lián)網(wǎng)的重要組成部分。必須用于在頂層分隔符之后,除了當自己指定時。 1. 問題描述 最近,本實驗室大量上馬云測量,云監(jiān)控方面的項目,大概是屬于物聯(lián)網(wǎng)應用的一個分支。老板也有將舊有儀器改造的想法,所以要實現(xiàn)儀器設備的云控制。本文是其中的一個解決方案。 2. 技術選型 消息隊列:M...

    張金寶 評論0 收藏0
  • 用 docker 部署 mosquitto 并編譯 mosquitto-auth-plug

    摘要:再運行一次它往發(fā)送了一個消息我們可以看到就已經(jīng)收到了總結我們成功地搭建了一個的消息代理服務并為它編譯了可以供后續(xù)后端消息業(yè)務的開發(fā)詳細代碼也可以參考已經(jīng)上傳到的 mosquitto 的簡介 mosquitto 是一個開源的輕量級消息代理服務, 支持 MQTT-3.1 和 MQTT-3.1.1, 采用發(fā)布訂閱模式. mosquitto 目前廣泛用于手機設備, 底端傳感器, 嵌入式計算機的...

    maybe_009 評論0 收藏0
  • PHP 使用mosquiito

    摘要:近期業(yè)務需要,調研和使用基于協(xié)議的,開發(fā)一個消息推送系統(tǒng)。環(huán)境安裝安裝的擴展然后把加到重啟編寫代碼,訂閱為的消息想為,發(fā)布消息運行腳本發(fā)布消息腳本接受到消息并且打印出來腳本中,在收到消息后,會發(fā)布一個消息到為中,后臺會接收消息 近期業(yè)務需要,調研和使用基于mqtt協(xié)議的mosquitto,開發(fā)一個消息推送系統(tǒng)。 環(huán)境:ubuntu 14.04,php7.1,mosquitto 安裝mo...

    Developer 評論0 收藏0

發(fā)表評論

0條評論

閱讀需要支付1元查看
<