色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

使用MQTT作為進程間通信的方式

strongerHuang ? 來源:CSDN技術社區 ? 作者:CSDN技術社區 ? 2020-10-22 12:09 ? 次閱讀

小編對Linux這一塊的實際開發經驗雖然還不是很足,但也知道進程間通信有那么幾種方式:管道、消息隊列、共享內存、套接字等。

某項目中使用了MQTT作為進程間的通信方式,感覺很新穎,網上好像也比較少有看到使用MQTT來作為進程間通信的方式的。這兩篇筆記我們就來一起學習一下這種方式。

MQTT的一些介紹

MQTT 協議全稱是 Message Queuing Telemetry Transport,翻譯過來就是消息隊列遙測傳輸協議,它是物聯網常用的應用層協議,運行在 TCP/IP 中的應用層中,依賴 TCP 協議,因此它具有非常高的可靠性,同時它是基于 TCP 協議的<客戶端-服務器>模型發布/訂閱主題消息的輕量級協議。

1、MQTT通信模型

MQTT協議是基于客戶端-服務器模型,在協議中主要有三種身份:發布者(Publisher)、服務器(Broker) 以及訂閱者(Subscriber)。 并且消息發布者可以同時是訂閱者 。

MQTT 消息的發布者和訂閱者都是客戶端,服務器只是作為一個中轉的存在,將發布者發布的消息進行轉發給所有訂閱該主題的訂閱者。

MQTT 客戶端的功能:

發布消息給其它相關的客戶端。

訂閱主題請求接收相關的應用消息。

取消訂閱主題請求移除接收應用消息。

從服務端終止連接。

MQTT 服務器常被稱為 Broker(消息代理) 。它的功能有:

接受來自客戶端的網絡連接請求。

接受客戶端發布的應用消息。

處理客戶端的訂閱和取消訂閱請求。

轉發應用消息給符合條件的已訂閱客戶端(包括發布者自身)。

2、MQTT消息

MQTT所發的消息包含:主題+內容,客戶端可以訂閱任意主題,若有其它客戶端發布主題時符合所訂閱的主題,就會由網關發送到客戶端。

「什么是主題?」

MQTT 服務器為每個連接的客戶端(訂閱者)添加一個標簽,該標簽與服務器中的所有訂閱相匹配, 服務器會將消息轉發給與標簽相匹配的每個客戶端。這樣的一個標簽就是主題。

「服務質量:」

MQTT提供三種服務質量(Quality of Service,簡寫QoS),供開發者根據不同的情景選擇不同的服務級別:

QoS0:最多發送一次消息,在消息發送出去后,接收者不會發送回應,發送者也不會重發消息。

QoS1:最少發送一次消息(消息最少需要送達一次,也有可送達多次), QoS 1的 PUBLISH 報文的可變報頭中包含一個報文標識符,需要 PUBACK 報文確認。

QoS2:這是最高等級的服務質量,消息丟失和重復都是不可接受的。只不過使用這個服務質量等級會有額外的開銷,這個等級常用于支付中,因為支付是必須有且僅有一次成功,總不能沒給錢或者給了多次錢吧。

mosquitto的使用

1、mosquitto簡介

mosquitto是一款開源的MQTT消息代理(服務器)軟件,提供輕量級的,支持可發布/可訂閱的的消息推送模式,使設備對設備之間的短消息通信變得簡單,比如現在應用廣泛的低功耗傳感器手機、嵌入式計算機、微型控制器等移動設備。

2、mosquitto實踐

從以上鏈接下載mosquitto源碼,得到:

在mosquitto路徑下,依次輸入如下命令編譯:

mkdirbuild cdbuild cmake../ make

若未安裝cmake則需要自行安裝,可參考往期文章:《面試官:Linux下如何編譯C程序?》

若執行cmake ../指令時出現Could NOT find OpenSSL的問題:

可輸入如下命令安裝OpenSSL(Ubuntu下):

sudo apt-get install libssl-dev

執行make編譯完成后,我們可以看到build目錄下的client與src文件夾下會生成一些可執行文件:

我們重點關注mosquitto_pub、mosquitto_sub、mosquitto這三個可執行文件。其中mosquitto是服務器軟件,mosquitto_pub是發布者客戶端,mosquitto_sub訂閱者客戶端。

下面我們來簡單測試一下:

其中,mosquitto_pub對應的源文件為mosquitto/client/pub_client.c,mosquitto_sub對應的源文件為mosquitto/client/sub_client.c,感興趣的朋友可自行閱讀學習。

這個示例其實就是兩個進程間的通信,前提是需要一個本地代理服務器。如果需要應用于我們嵌入式Linux中的進程間通信,需要使用交叉編譯器編譯出一個可運行在我們的arm板上的mosquitto服務器。

責任編輯人:CC

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • MQTT
    +關注

    關注

    5

    文章

    653

    瀏覽量

    22622
  • MQTT協議
    +關注

    關注

    0

    文章

    98

    瀏覽量

    5455

原文標題:簡單認識認識mqtt及mosquitto

文章出處:【微信號:strongerHuang,微信公眾號:strongerHuang】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    Linux下進程如何實現共享內存通信

    這次我們來講一下Linux進程通信中重要的通信方式:共享內存作為Linux軟件開發攻城獅,進程
    發表于 04-26 17:14 ?703次閱讀

    Linux下進程通信方式-管道

    Linux下進程通信方式-管道分享到: 本文關鍵字: linux 管道通信,linux 進程
    發表于 08-29 15:29

    Linux現有的所有進程IPC方式

    ;不合適頻繁或信息量大的通信;3. 共享內存:無須復制,共享緩沖區直接付附加到進程虛擬地址空間,速度快;但進程的同步問題操作系統無法實現,必須各
    發表于 08-20 06:17

    常用的進程通信主要有哪幾種方式

    這里說的嵌入式系統,是嵌入式linux系統,嵌入式linux系統其實和電腦端的linux系統一樣,作為一個系統,就不可能就跑一個程序或者任務,大多都會有好幾個進程,這樣的話就會用到進程
    發表于 11-08 07:38

    進程通信方式有哪些?

    進程通信方式有哪些?
    發表于 12-24 06:46

    哪些方式可以實現Linux系統下的進程通信

    哪些方式可以實現Linux系統下的進程通信?進程與線程有哪些不同之處呢?
    發表于 12-24 06:38

    進程通信之Linux下進程通信概述

    在上一章中,讀者已經知道了進程是一個程序的一次執行。這里所說的進程一般是指運行在用戶態的進程,而由于處于用戶態的不同進程之間是彼此隔離的,就像處于不同城市的人們,它們必須通過某種
    發表于 10-18 16:21 ?0次下載

    進程與線程通信方式

    進程通信則不同,它的數據空間的獨立性決定了它的通信相對比較復雜,需要通過操作系統。以前進程
    的頭像 發表于 04-09 15:58 ?8953次閱讀
    <b class='flag-5'>進程</b><b class='flag-5'>間</b>與線程<b class='flag-5'>間</b>的<b class='flag-5'>通信</b><b class='flag-5'>方式</b>

    Linux進程通信方式——管道

    管道是Linux中進程通信的一種方式,它把一個程序的輸出直接連接到另一個程序的輸入。Linux的管道主要包括兩種:無名管道和有名管道。
    發表于 06-01 09:13 ?1475次閱讀
    Linux<b class='flag-5'>進程</b><b class='flag-5'>間</b><b class='flag-5'>通信</b><b class='flag-5'>方式</b>——管道

    Linux進程的五種通信方式介紹 4

    進程通信(IPC,InterProcess Communication)是指在不同進程之間傳播或交換信息。IPC的方式通常有管道(包括無名
    的頭像 發表于 02-15 10:19 ?622次閱讀

    Linux進程的五種通信方式介紹 5

    進程通信(IPC,InterProcess Communication)是指在不同進程之間傳播或交換信息。IPC的方式通常有管道(包括無名
    的頭像 發表于 02-15 10:20 ?620次閱讀

    進程通信的機制有哪些

    進程通信(interprocess communication,簡稱IPC)指兩個進程之間的通信。系統中的每一個
    的頭像 發表于 07-21 11:23 ?977次閱讀
    <b class='flag-5'>進程</b><b class='flag-5'>間</b><b class='flag-5'>通信</b>的機制有哪些

    常見的進程通信方式

    進程通信 如果兩個進程,想要知道對方在干嘛,或者進行協調運行,就需要進程
    的頭像 發表于 10-08 15:48 ?1388次閱讀
    常見的<b class='flag-5'>進程</b><b class='flag-5'>間</b><b class='flag-5'>通信</b><b class='flag-5'>方式</b>

    進程通信方式總結

    進程通信(IPC): 進程通信方式有很多,這里
    的頭像 發表于 11-09 09:25 ?804次閱讀
    <b class='flag-5'>進程</b><b class='flag-5'>間</b><b class='flag-5'>通信</b><b class='flag-5'>方式</b>總結

    進程通信的消息隊列介紹

    消息隊列是一種非常常見的進程通信方式
    的頭像 發表于 04-08 17:27 ?334次閱讀
    主站蜘蛛池模板: 成人AV精品视频| 精品国产乱码久久久久乱码| 99re久久热在线播放快| 伦理片97影视网| 国产亚洲精品AV麻豆狂野| 厕所xxxxx| 俄罗斯15一16处交| YELLOW日本动漫免费动漫| 白银谷在线观看| 国产激情一级毛片久久久| 国模啪啪久久久久久久| 久久免费精彩视频| 久久成人无码国产免费播放| 国产在线观看www鲁啊鲁免费| 国产免费69成人精品视频| 国产精品玖玖玖影院| 黄色大片久久| 免费人成网站在线观看10分钟| 久久精品中文騷妇女内射| 免费在线看视频| 日韩一本在线| 亚洲裸舞 hd| 99视频精品全部免费免费观| 国产GV天堂亚洲国产GV刚刚碰| 好想被狂躁A片免费久99| 考好老师让你做一次H| 老湿机一区午夜精品免费福利 | 一级做a爰片久久毛片免费| 97人妻精品全国免费视频| 干了快生了的孕妇| 精品国产九九| 热热久久超碰精品中文字幕 | 久热人人综合人人九九精品视频| 青草在线在线d青草在线| 亚洲AV无码久久流水呻蜜桃久色 | 久久99re2热在线播放7| 欧美日韩另类在线观看视频| 青柠在线观看免费完整版| 羲义嫁密着中出交尾gvg794| 亚洲精品高清中文字幕完整版| 91麻豆精品一二三区在线|