https://www.cnblogs.com/dissun/p/10505007.html
關鍵字:在windows安裝mosquitto,在mosquitto中配置日志,在mosquitto中配置用戶賬號密碼
關於Mosquitto配置的資料網上還是有幾篇的,但是看來看去,基本上都是基於Linux。基於Window的鳳毛麟角,看上去貌似配置的東西相差不大,實操過程中真的煩透了,配置就是不成功,這次把自己實踐過程中的東西記錄一下,分享出來。
一、概念梳理
1、Mosquitto是一款實現了消息推送協議MQTT 3.1的開源消息代理軟件,提供輕量級的、支持可訂閱/可發布的消息推送模式,是設備與設備之間的短消息通信變得簡單,廣泛應用於低功耗傳感器、手機(app消息推送是場景之一)、嵌入式電腦、微型控制器等移動設備。
2、那什么是MQTT,他的英文全稱Message Queuing Telemetry Transport,翻譯過來就是“消息隊列遙測傳輸”,是ISO 標准(ISO/IEC PRF 20922)下基於發布/訂閱范式的消息協議。它工作在 TCP/IP協議族上,是為硬件性能低下的遠程設備以及網絡狀況糟糕的情況下而設計的發布/訂閱型消息協議。
目前支持MQTT的服務器中間件有EMQTT、Mosquitto、Apollo。本章講的就是Mosquitto。
3、MQTT的協議內容有很多,其中一個一定要知道,就是“消息發布服務質量”,只有三個值分別是:
QoS 0:“至多一次”,消息發布完全依賴底層 TCP/IP 網絡。會發生消息丟失或重復。這一級別可用於如下情況,環境傳感器數據,丟失一次讀記錄無所謂,因為不久后還會有第二次發送。
QoS 1:“至少一次”,確保消息到達,但消息重復可能會發生。
QoS 2:“只有一次”,確保消息到達一次。這一級別可用於如下情況,在計費系統中,消息重復或丟失會導致不正確的結果。
二、下載與安裝
1、Mosquitto存在很多版本,如果想體驗比較新版本可以上github,但是比較麻煩的是需要自己去編譯成windows文件,編譯需要用到cmake軟件,我之前操作過沒問題,可以參照其他博主的文章:[https://blog.csdn.net/vwadev/article/details/50148265]。
官方后面提供了比較穩定的window安裝版本,安裝完成后可以直接使用,並且自動添加成 windows服務,非常方便,下載路徑:https://mosquitto.org/download
2、安裝完成。如果需要使用,直接啟動服務即可。
3、Mosquitto服務默認占用 1883端口,所以可不在配置文件中顯式設置。
三、關於配置文件的一些重要說明
1、配置文件在安裝目錄下的mosquitto.conf,默認情況下不做任何修改,就可以啟動mosquitto。
2、配置說明中出現的地址例如:“/var/run/mosquitto”,“/var/log/messages”,都是相對路徑,相對於系統盤根目錄。這個地方很重要,他可不是相對於安裝目錄的根目錄。例如“/var/run/mosquitto”表示的是“c:\var\run\mosquitto”,我有一段時間一直沒搞定,就是這個目錄原因,很多人沒有反饋這個問題,因為都是在linux用所以沒啥問題。
3、安裝目錄的完整路徑中,不能出現空格,否則在命令行就無法通過。Mosquitto默認安裝路徑是在“C:\Program Files\mosquitto”,這里面的“Program Files”就存在空格,導致很多問題,這個也要特別注意。所以后來我改為安裝在“C:\MosquittoTest”
四、配置登錄賬號和密碼
1、如果想方便測試可以下載安裝MQTT客戶端(http://www.eclipse.org/paho/components/tool/),我自己是用這個,不過下面我們還是用原生的命令行操作:
2、在配置文件mosquitto.conf中,任意位置加入下面文本,保存退出(我說的全新安裝的情況下,如果是維護已經使用很久的系統,可在配置文件中找到對應的屬性進行更改)
#設置不允許匿名登錄 allow_anonymous false #設置賬戶密碼文件位置為C:\MosquittoTest\pwfile.example password_file /MosquittoTest/pwfile.example
3、重啟mosquitto服務配置文件的修改才能生效。為了方便調試和操作,我們后面的操作全部通過命令行模式進行。
4、插入新用戶名及密碼,輸入密碼時界面是不會顯示的,直接輸入后回車就可以,需要連續輸入兩次。保證pwfile.example的路徑和上面的配置一致。下面打開CMD並進入mosquitto根目錄輸入:
mosquitto_passwd -c /MosquittoTest/pwfile.example FirstUserName (使用-c 參數會導致清空密碼文件,重新插入用戶)
mosquitto_passwd /MosquittoTest/pwfile.example SecondUserName (不使用-c 表示追加用戶,不影響舊用戶)
5、創建成功后pwfile.example會出現剛剛添加的用戶信息。
6、啟動mosquitto 進行測試。
首先啟動第一個cmd窗口啟動服務:mosquitto.exe -c mosquitto.conf
然后啟動第二個cmd窗口訂閱'dissun/topic'主題(其中dissun是賬號,111111是密碼):mosquitto_sub -u dissun -P 111111 -t 'dissun/topic' -v
最后啟動第三個cmd窗口發布訂閱'腰疼不加班'信息:mosquitto_pub -u dissun -P 111111 -t 'dissun/topic' -m '腰疼不加班'
五、配置日期信息
1、配置日期前請先查看第三大點(關於配置文件的一些重要說明)
2、在mosquitto.conf文件中插入:
#把日志信息輸入到指定文件 log_dest file /MosquittoTest/DisSunLog_1.log #在控制台輸出信息,運行win服務無效 log_dest stdout #不記錄 #log_type none #########下面的debug、error、warning.....等等可以組合使用。 #記錄網絡通信包,通信包大小(含心跳包),但不顯示內容 log_type debug #錯誤信息(沒見過) log_type error #警告信息(沒見過) log_type warning #設備的訂閱信息、發布信息及下線信息(端口、設備名、用戶、不包發布內容) log_type notice #服務啟動關閉信息、版本號、端口號、配置文件信息 log_type information #所有設備訂閱主題提醒 log_type subscribe #這個沒有試出來干啥用的(沒見過) #log_type unsubscribe #websockets鏈接信息(沒見過) #log_type websockets #websockets_log_level 0
3、然后重啟服務,我們發一條信息來看看記錄了什么。(參照第四節第6點進行發送信息操作得到下面運行界面)
4、按Ctrl+C 停止主服務,如果不停止服務,日志文件會被獨占鎖住無法打開。找到這個日志
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信息,發布客戶端上線12284 1552112832: New connection from ::1 on port 1883. 1552112832: New client connected from ::1 as mosqpub|12284-DisSunPad (c1, k60, u'dissun'). ##########:以下是debug信息,發布客戶端上線12284,並發布12字節的信息,然后離線。 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信息,發布客戶端離線12284 1552112832: Client mosqpub|12284-DisSunPad disconnected. ##########:以下是debug信息,訂閱客戶端保持跟mosquitto的聯系。PINGREQ請求心跳包,PINGRESP回應心跳包 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信息 主服務中斷 1552113191: mosquitto version 1.5.8 terminating
六、如果要開啟webSockets,它是支持的。但是要顯式的加入mqtt協議及端口
#MQTT協議
port 1883
protocol mqtt
#websockets協議
listener 8000
protocol websockets
#如果需要查看websockets日志還可以加入以下面,上面有提過。
log_type websockets
websockets_log_level 0
七、用戶訪問控制acl_file,看遍了所有的文章,操作都不生效。加了訪問控制后所有的的用戶,都無法正常的收發信息,所以等下次研究透了再追加。感覺這玩意從Linux移至過來,不是完全通用。
不過還是按照說明把操作寫下來,有看出問題的童鞋可以跟我反饋下。(注:下面的內容操作沒有通過,請讀者自行試驗)
1、在mosquitto.cong中間中加入
#加入訪問控制列表文件Acls
acl_file /MosquittoTest/aclfile.example
2、修改aclfile.example內容,加入用戶的權限
# 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、按道理說設置就是這么多,沒那么復雜,但是此時dissun用戶訂閱是成功的,但是dissun用戶發布失敗,服務debug日志顯示“denied”。我懷疑是acl文件加載失敗,所以換了絕對路徑,但是依然沒有效果,搞了一下午不成功放棄,以后再搞。
#### 原創:DisSun ##########
#### 時間:2019.03.10 #######