欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Windows環(huán)境下安裝配置Mosquitto服務(wù)及入門操作介紹詳解

 更新時間:2017年08月18日 10:56:56   作者:第三皇族DisSun  
這篇文章主要為大家詳細(xì)介紹了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)文章

最新評論