Windows環(huán)境下安裝配置Mosquitto服務(wù)及入門操作介紹詳解
關(guān)于Mosquitto配置的資料網(wǎng)上還是有幾篇的,但是看來看去,基本上都是基于Linux。基于Window的鳳毛麟角,看上去貌似配置的東西相差不大,實操過程中真的煩透了,配置就是不成功,這次把自己實踐過程中的東西記錄一下,分享出來。
一、概念梳理
1、Mosquitto是一款實現(xiàn)了消息推送協(xié)議MQTT 3.1的開源消息代理軟件,提供輕量級的、支持可訂閱/可發(fā)布的消息推送模式,是設(shè)備與設(shè)備之間的短消息通信變得簡單,廣泛應(yīng)用于低功耗傳感器、手機(app消息推送是場景之一)、嵌入式電腦、微型控制器等移動設(shè)備。
2、那什么是MQTT,他的英文全稱Message Queuing Telemetry Transport,翻譯過來就是“消息隊列遙測傳輸”,是ISO 標(biāo)準(zhǔn)(ISO/IEC PRF 20922)下基于發(fā)布/訂閱范式的消息協(xié)議。它工作在 TCP/IP協(xié)議族上,是為硬件性能低下的遠(yuǎn)程設(shè)備以及網(wǎng)絡(luò)狀況糟糕的情況下而設(shè)計的發(fā)布/訂閱型消息協(xié)議。
目前支持MQTT的服務(wù)器中間件有EMQTT、Mosquitto、Apollo。本章講的就是Mosquitto。
3、MQTT的協(xié)議內(nèi)容有很多,其中一個一定要知道,就是“消息發(fā)布服務(wù)質(zhì)量”,只有三個值分別是:
- QoS 0:“至多一次”,消息發(fā)布完全依賴底層 TCP/IP 網(wǎng)絡(luò)。會發(fā)生消息丟失或重復(fù)。這一級別可用于如下情況,環(huán)境傳感器數(shù)據(jù),丟失一次讀記錄無所謂,因為不久后還會有第二次發(fā)送。
- QoS 1:“至少一次”,確保消息到達,但消息重復(fù)可能會發(fā)生。
- QoS 2:“只有一次”,確保消息到達一次。這一級別可用于如下情況,在計費系統(tǒng)中,消息重復(fù)或丟失會導(dǎo)致不正確的結(jié)果。
二、下載與安裝
1、Mosquitto存在很多版本,如果想體驗比較新版本可以上github,但是比較麻煩的是需要自己去編譯成windows文件,編譯需要用到cmake軟件
官方后面提供了比較穩(wěn)定的window安裝版本,安裝完成后可以直接使用,并且自動添加成 windows服務(wù),非常方便,下載路徑:https://mosquitto.org/download
2、安裝完成。如果需要使用,直接啟動服務(wù)即可。
3、Mosquitto服務(wù)默認(rèn)占用 1883端口,所以可不在配置文件中顯式設(shè)置。
三、關(guān)于配置文件的一些重要說明
1、配置文件在安裝目錄下的mosquitto.conf,默認(rèn)情況下不做任何修改,就可以啟動mosquitto。
2、配置說明中出現(xiàn)的地址例如:“/var/run/mosquitto”,“/var/log/messages”,都是相對路徑,相對于系統(tǒng)盤根目錄。這個地方很重要,他可不是相對于安裝目錄的根目錄。例如“/var/run/mosquitto”表示的是“c:\var\run\mosquitto”,我有一段時間一直沒搞定,就是這個目錄原因,很多人沒有反饋這個問題,因為都是在linux用所以沒啥問題。
3、安裝目錄的完整路徑中,不能出現(xiàn)空格,否則在命令行就無法通過。Mosquitto默認(rèn)安裝路徑是在“C:\Program Files\mosquitto”,這里面的“Program Files”就存在空格,導(dǎo)致很多問題,這個也要特別注意。所以后來我改為安裝在“C:\MosquittoTest”
四、配置登錄賬號和密碼
1、如果想方便測試可以下載安裝MQTT客戶端(http://www.eclipse.org/paho/components/tool/),我自己是用這個,不過下面我們還是用原生的命令行操作:
2、在配置文件mosquitto.conf中,任意位置加入下面文本,保存退出(我說的全新安裝的情況下,如果是維護已經(jīng)使用很久的系統(tǒng),可在配置文件中找到對應(yīng)的屬性進行更改)
#設(shè)置不允許匿名登錄 allow_anonymous false #設(shè)置賬戶密碼文件位置為C:\MosquittoTest\pwfile.example password_file /MosquittoTest/pwfile.example
3、重啟mosquitto服務(wù)配置文件的修改才能生效。為了方便調(diào)試和操作,我們后面的操作全部通過命令行模式進行。
4、插入新用戶名及密碼,輸入密碼時界面是不會顯示的,直接輸入后回車就可以,需要連續(xù)輸入兩次。保證pwfile.example的路徑和上面的配置一致。下面打開CMD并進入mosquitto根目錄輸入:
mosquitto_passwd -c /MosquittoTest/pwfile.example FirstUserName (使用-c 參數(shù)會導(dǎo)致清空密碼文件,重新插入用戶)
mosquitto_passwd /MosquittoTest/pwfile.example SecondUserName (不使用-c 表示追加用戶,不影響舊用戶)
5、創(chuàng)建成功后pwfile.example會出現(xiàn)剛剛添加的用戶信息。
6、啟動mosquitto 進行測試。
首先啟動第一個cmd窗口啟動服務(wù):mosquitto.exe -c mosquitto.conf
然后啟動第二個cmd窗口訂閱'dissun/topic'主題(其中dissun是賬號,111111是密碼):mosquitto_sub -u dissun -P 111111 -t 'dissun/topic' -v
最后啟動第三個cmd窗口發(fā)布訂閱'腰疼不加班'信息:mosquitto_pub -u dissun -P 111111 -t 'dissun/topic' -m '腰疼不加班'
五、配置日期信息
1、配置日期前請先查看第三大點(關(guān)于配置文件的一些重要說明)
2、在mosquitto.conf文件中插入:
#把日志信息輸入到指定文件 log_dest file /MosquittoTest/DisSunLog_1.log #在控制臺輸出信息,運行win服務(wù)無效 log_dest stdout #不記錄 #log_type none #########下面的debug、error、warning.....等等可以組合使用。 #記錄網(wǎng)絡(luò)通信包,通信包大?。ê奶?,但不顯示內(nèi)容 log_type debug #錯誤信息(沒見過) log_type error #警告信息(沒見過) log_type warning #設(shè)備的訂閱信息、發(fā)布信息及下線信息(端口、設(shè)備名、用戶、不包發(fā)布內(nèi)容) log_type notice #服務(wù)啟動關(guān)閉信息、版本號、端口號、配置文件信息 log_type information #所有設(shè)備訂閱主題提醒 log_type subscribe #這個沒有試出來干啥用的(沒見過) #log_type unsubscribe #websockets鏈接信息(沒見過) #log_type websockets #websockets_log_level 0
3、然后重啟服務(wù),我們發(fā)一條信息來看看記錄了什么。(參照第四節(jié)第6點進行發(fā)送信息操作得到下面運行界面)
4、按Ctrl+C 停止主服務(wù),如果不停止服務(wù),日志文件會被獨占鎖住無法打開。找到這個日志
5、日志解析
##########:以下是information信息 1552112775: mosquitto version 1.5.8 starting 1552112775: Config loaded from mosquitto.conf. 1552112775: Opening ipv6 listen socket on port 1883. 1552112775: Opening ipv4 listen socket on port 1883. ##########:以下是subscribe信息(偽造) 1552113940: mosqsub|11332-DisSunPad 0 'dissun/topic' 20-DisSunPad (c1, k60, u'dissun'). ##########:以下是notice信息,訂閱客戶端上線11332 1552112782: New connection from ::1 on port 1883. 1552112782: New client connected from ::1 as mosqsub|11332-DisSunPad (c1, k60, u'dissun'). ##########:以下是debug信息,訂閱客戶端上線11332 1552112782: No will message specified. 1552112782: Sending CONNACK to mosqsub|11332-DisSunPad (0, 0) 1552112782: Received SUBSCRIBE from mosqsub|11332-DisSunPad 1552112782: 'dissun/topic' (QoS 0) 1552112782: mosqsub|11332-DisSunPad 0 'dissun/topic' 1552112782: Sending SUBACK to mosqsub|11332-DisSunPad ##########:以下是notice信息,發(fā)布客戶端上線12284 1552112832: New connection from ::1 on port 1883. 1552112832: New client connected from ::1 as mosqpub|12284-DisSunPad (c1, k60, u'dissun'). ##########:以下是debug信息,發(fā)布客戶端上線12284,并發(fā)布12字節(jié)的信息,然后離線。 1552112832: No will message specified. 1552112832: Sending CONNACK to mosqpub|12284-DisSunPad (0, 0) 1552112832: Received PUBLISH from mosqpub|12284-DisSunPad (d0, q0, r0, m0, ''dissun/topic'', ... (12 bytes)) 1552112832: Sending PUBLISH to mosqsub|11332-DisSunPad (d0, q0, r0, m0, ''dissun/topic'', ... (12 bytes)) 1552112832: Received DISCONNECT from mosqpub|12284-DisSunPad ##########:以下是notice信息,發(fā)布客戶端離線12284 1552112832: Client mosqpub|12284-DisSunPad disconnected. ##########:以下是debug信息,訂閱客戶端保持跟mosquitto的聯(lián)系。PINGREQ請求心跳包,PINGRESP回應(yīng)心跳包 1552112842: Received PINGREQ from mosqsub|11332-DisSunPad 1552112842: Sending PINGRESP to mosqsub|11332-DisSunPad 1552112902: Received PINGREQ from mosqsub|11332-DisSunPad 1552112902: Sending PINGRESP to mosqsub|11332-DisSunPad 1552112962: Received PINGREQ from mosqsub|11332-DisSunPad ##########:以下是information信息 主服務(wù)中斷 1552113191: mosquitto version 1.5.8 terminating
六、如果要開啟webSockets,它是支持的。但是要顯式的加入mqtt協(xié)議及端口
#MQTT協(xié)議
port 1883
protocol mqtt
#websockets協(xié)議
listener 8000
protocol websockets
#如果需要查看websockets日志還可以加入以下面,上面有提過。
log_type websockets
websockets_log_level 0
七、用戶訪問控制acl_file,看遍了所有的文章,操作都不生效。加了訪問控制后所有的的用戶,都無法正常的收發(fā)信息,所以等下次研究透了再追加。感覺這玩意從Linux移至過來,不是完全通用。
不過還是按照說明把操作寫下來,有看出問題的童鞋可以跟我反饋下。(注:下面的內(nèi)容操作沒有通過,請讀者自行試驗)
1、在mosquitto.cong中間中加入
#加入訪問控制列表文件Acls acl_file /MosquittoTest/aclfile.example
2、修改aclfile.example內(nèi)容,加入用戶的權(quán)限
# This affects access control for clients with no username. topic read $SYS/# # This only affects clients with username "roger". #user roger #topic foo/bar user dissun topic dissun/topic # This affects all clients. pattern write $SYS/broker/connection/%c/state
3、CMD啟動mosquitto。
4、按道理說設(shè)置就是這么多,沒那么復(fù)雜,但是此時dissun用戶訂閱是成功的,但是dissun用戶發(fā)布失敗,服務(wù)debug日志顯示“denied”。我懷疑是acl文件加載失敗,所以換了絕對路徑,但是依然沒有效果,搞了一下午不成功放棄,以后再搞。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
比較詳細(xì)的win2003 IIS6.0 301重定向帶參數(shù)的問題解決方法
從iis中設(shè)置url永久轉(zhuǎn)向就可以,看上去很容易,用了一會兒才發(fā)現(xiàn),參數(shù)都沒有帶上。2007-11-11win2008下IIS7、IIS7.5 配置ASP+ACCESS使用環(huán)境
Windows 中IIS7、IIS7.5是默認(rèn)不安裝的,所以在安裝完Windows Vista/windows 7/windows 2008之后如果需要安裝IIS7/iis7.5的話,就要自己動手了。2011-04-04IIS自定義404錯誤頁避免暴露.NET網(wǎng)站路徑信息
這篇文章主要介紹了IIS自定義404錯誤頁避免暴露.NET網(wǎng)站路徑信息,在輸入非.aspx頁面時,顯示默認(rèn)404頁面,暴露站點路徑信息,本文就給出了一個解決方法,需要的朋友可以參考下2015-06-06Microsoft VBScript 運行時錯誤 錯誤 ''800a0046'' 沒有權(quán)限
Microsoft VBScript 運行時錯誤 錯誤 '800a0046' 沒有權(quán)限2009-06-06提示iis 無法啟動World Wide Web Publishing服務(wù)的解決辦法
今天裝IIS組件,結(jié)果網(wǎng)站和ftp都啟動不了,看看服務(wù),World Wide Web Publishing 服務(wù)沒有啟動,F(xiàn)TP Publishing服務(wù)也沒有啟動,于是我手動啟動World Wide Web Publishing 服務(wù),郁悶的是,系統(tǒng)提示:無法啟動World Wide Web Publishing服務(wù),錯誤 87 , 參數(shù)不正確;2008-11-11