MQTT客户端设置

MQTT客户端设置,第1张

MQTTBox

从MQTTBox应用程序创建新的MQTT客户端时,您可以指定各种连接设置。大多数设置默认设置为最常用的值,但是您可能仍需要自定义设置以根据需要测试MQTT客户端。本文档详细解释了每个客户端设置属性,以便更好地理解客户端连接和实际的MQTT协议。

MQTT客户端名称: 用于标识MQTT客户端并在仪表板上显示的名称。它可以是任何字符串值。

例如:client_test_1

客户端ID: 客户端标识符是连接到MQTT代理的每个MQTT客户端的标识符。对于给定的经纪人,每个客户应该是唯一的。代理使用它来识别客户端和客户端的当前状态。它默认是自动生成的。如果尝试连接具有相同客户端标识符的两个MQTT客户端,则代理将拒绝连接。当您打开2个MQTTBox应用程序实例时,请确保您拥有唯一的客户端ID,否则您的客户将被代理拒绝并可能显示为脱机。

例如:client_id_1

将时间戳附加到MQTT客户端ID?: 如果选中,则时间戳将附加到客户端ID。默认情况下启用此选项。很多时候,用户在相同或不同的机器上打开多个MQTTBox应用程序实例,这些机器具有相同的MQTT客户端设置,包括不同的客户端ID。这会导致客户端连接由于相同的客户端ID而被代理拒绝。如果启用此选项,MQTTBox会将时间戳附加到每个客户端ID,使其几乎唯一,这有助于您节省调试不必要问题的时间。

Broker是否符合MQTT v3.1.1 ?: 如果要连接的MQTT代理仅支持旧版本的MQTT协议3.1或更低版本(v3.1.1是最新版本和当前标准版),则应取消选中此选项。默认情况下,它会被检查并假定MQTT代理符合当前的MQTT标准v3.1.1(或更高版本)。

协议: MQTT客户端用于连接MQTT代理的网络协议。

MQTTBox支持TCP,SSL / TLS,MQTT,MQTTS,WebSockets(WS)和Secure WebSockets(WSS)。根据您使用MQTTBox应用程序的平台,由于平台限制,可能不支持所有协议。

请 在此处 查看每个平台支持的MQTTBox功能列表。

主机: 要连接的MQTT主机。确保根据所选的MQTT连接协议指定正确的主机和端口号。如果您提到错误的端口号或交换端口号,MQTT客户端可能无法连接。

例如:test.mosquitto.org:8080

Clean Session? :clean session标志指示代理是否客户端想要建立持久会话。如果您需要持久会话,即代理将存储客户端的所有订阅以及所有丢失的消息,则在订阅服务质量(QoS)1或2时,取消选中/不选择此选项。默认情况下会选中此选项或是,这意味着代理将启动新会话,不会为客户端存储任何内容,也会清除先前持久会话中的所有信息。

在应用程序启动时自动连接?: 如果您选中/是此选项,客户端将尝试在启动MQTTBox应用程序时自动连接到代理,并且可以处于“已连接”或“连接错误”状态,具体取决于客户端是否已连接到代理或不。如果未选中/没有此选项,客户端将处于“未连接”状态,您需要手动将客户端连接到代理。

您可以从MQTTBox仪表板连接,断开连接,重新连接MQTT客户端

用户名 经纪人所需的用户名(如果有)。MQTT允许发送用于验证和授权客户端的用户名。

密码: 经纪人要求的密码(如果有)。MQTT允许发送密码以进行客户端的身份验证和授权。 请注意,所有密码都以纯文本格式保存。确保您永远不会在MQTTBox应用程序中保存生产密码。事实上,所有字段都保存为纯文本,请确保您永远不会在MQTTBox应用程序中保存任何敏感信息/设置

重新安排Ping? 如果选中/是,则在发送数据包后重新安排ping消息。

队列传出QoS零消息: 如果选中/是,如果客户端和代理之间的连接断开,则客户端队列的传出QoS零消息。建立连接后,将发布所有这些消息。

重新连接周期(以毫秒为单位): 两次重新连接之间的间隔

连接超时(以毫秒为单位): 收到CONNACK之前等待的时间

KeepAlive(以秒为单位): keep alive是一个时间间隔,客户端通过向代理发送常规PING请求消息来提交。具有PING响应和这种机制的代理响应将允许双方确定另一方是否仍然存活且可达。默认设置为10秒,设置为0表示禁用。

Will Settings - will消息是MQTT Client最后遗嘱的一部分。当客户端断开连接时,它允许通知其他客户端。连接客户端将在CONNECT消息中以MQTT消息和主题的形式提供其意愿。如果此客户端无法正常断开连接,则代理会自动代表客户端发送此消息。

将设置 - 主题: 要发布的主题将是有效负载。一个简单的字符串,可以使用正斜杠作为分隔符进行分层结构化。

例如:topic_test_1或家庭/厨房/湿度

将设置 - QoS: 发布具有QoS集的有效负载。默认情况下为0。

将设置 - 保留: 保留will有效载荷的标志。

将设置 - 有效负载: 客户端断开连接时要发布的消息。

要发布 的主题 是要发布到的主题。一个简单的字符串,可以使用正斜杠作为分隔符进行分层结构化。

例如:topic_test_1或家庭/厨房/湿度

QoS: 此消息的服务质量等级(QoS)。级别(0,1或2)确定传递的消息的保证。

保留: 此标志确定代理是否将消息作为上一个已知的良好值保存到指定主题。订阅该主题的新客户将在订阅后立即收到有关该主题的最后保留消息。

要删除主题的保留消息,请发送包含该主题的零字节负载的保留消息。

有效负载: 这是要发布到主题的消息的实际内容。

主题: 是要订阅的String主题。您可以为主题指定单级(+)和多级(#)订阅。

例如:topic_test_1或家庭/ + /湿度或家庭/#

QoS: 此消息的服务质量等级(QoS)。级别(0,1或2)确定传递的消息的保证。

------HiWiFi_g54188---Sonoff------esp8266刷机命令---mdi-camera-account mdi-settings-box

安装esptool工具命令:pip install pyserial

esptool.py --port COM3 read_flash 0x00000 0x100000 image1M.bin //备份原固件

esptool.py --port COM3 erase_flash //清内存

esptool.py --port COM3 write_flash -fs 1MB -fm dout 0x0 sonoff.bin //写固件中文

esptool.py --port COM3 write_flash -fs 1MB -fm dout 0x0 sonoff-basic.bin //写固件中文1.12.3,默认用户名为 admin 密码为 fibnacci

esptool.py --port COM3 write_flash -fs 1MB -fm dout 0x0 sonoff_ch_1.bin //最大的空间

esptool.py --port COM3 write_flash -fs 1MB -fm dout 0x0 hassmart-three.bin

esptool.py --port COM3 write_flash -fs 1MB -fm dout 0x0 sonoff-basic-chs-1.12.1.bin

esptool.py --port COM4 write_flash -fs 1MB -fm dout 0x0 sonoff_ch_1.bin

esptool.py --port COM4 erase_flash

http://192336l3r3.iask.in/

armbian 网络WIFI编辑命令:sudo nmtui

--------HiWiFi_35B98C-------homekit:-----------------ESP 芯片 ID 3445083 ----34915B--

域名窃持192.168.2.129 Smartplugconnect.phicomm.com“

192.168.123.242 Smartplugconnect.phicomm.com

注意:如果刷了armbian想刷回安卓,断电,开机再插HUB线

如果不行,就强短接刷机。

先做armbian镜像完了把下面这个文件

meson-gxl-s905d-phicomm-n1.dtb //把这个文件添加到Armbian的ROOT/ADB文件夹里

然后在降级工具下的DATA文件夹下的地址栏输入cmd后输入以下命令开始刷安卓系统

adb.exe connect 192.168.2.169 //连接目标系统

adb.exe connect 192.168.2.127 //连接目标系统

adb.exe connect 192.168.123.163 //连接目标系统

adb.exe shell reboot update //目标系统u盘启动

/root/install.sh //把Armbian镜像到N1内存里

apt update //先更新下armbian系统

配置命令:armbian-config

注意:有时找不到WIFI的设置,应该是USB盘的(镜像)问题,多格式化几次EXT4格式在镜像试试,不用插网线就能设置wifi

然后选择下时区,一般是亚洲的香港

poweroff//关机

挂载的USB磁盘需是exfat格式,否则armbian系统不认识

//----------安装OMV-----

在armbian下输入armbian-config在这里先设置好WIFI或者加入有线网络后在菜单里选择安装omv

安装完成后在浏览器里输入IP就可以看见了,最好把端口改成8800

OMV

admin 默认密码:openmediavault

改源

nano /etc/apt/sources.list

----------------------

deb https://mirrors.ustc.edu.cn/debian stretch main contrib non-free

#deb-src http://httpredir.debian.org/debian stretch main contrib non-free

deb https://mirrors.ustc.edu.cn/debian stretch-updates main contrib non-free

#deb-src http://httpredir.debian.org/debian stretch-updates main contrib non-free

deb https://mirrors.ustc.edu.cn/debian stretch-backports main contrib non-free

#deb-src http://httpredir.debian.org/debian stretch-backports main contrib non-free

deb https://mirrors.ustc.edu.cn/debian-security/ stretch/updates main contrib non-free

#deb-src http://security.debian.org/ stretch/updates main contrib non-free

ctrl+o 回车保存

ctrl+x 退出

-----------------------

---------连接网络---网络编辑命令nmtui---

命令:armbian-config

例如给N1设置一个固定IP只需

命令行输入 armbian-config

选 network

选 eth0

选 ip

选 static

然后按需求填写即可。

Wi-Fi设置命令行输入 armbian-config

选 network

选 eth0

选 WiFi

找到对应WiFi信号回车

输入密码选OK

如果第一次没连上,可以多尝试几次

-------mqtt安装---------------

#更新下系统,更新前记得改国内源,不知怎么更换的看这贴:http://bbs.hassbian.com/thread-27-1-1.html

sudo apt-get update

sudo apt-get upgrade -y

#安装mosquitto

sudo apt-get install mosquitto

#更改mqtt设置(本来没有这文件,直接运行以下命令创建)

sudo nano /etc/mosquitto/conf.d/mqtt.conf

#在上面文件里加入(为保持与hassio版mqtt插件一致,同时为了使用我提供的mqtt测试工具,这里必须要启用websockets支持):

port 1883

listener 1884

protocol websockets

allow_anonymous false

#设置用户和密码,这里用户为mqtt,可改为你想设的用户名,回车后会让你输入密码,密码自设输入两遍,建议都设为mqtt

sudo mosquitto_passwd -c /etc/mosquitto/pwfile mqtt

设置开机启动

sudo /etc/init.d/mosquitto enable

#启动MQTT服务

sudo /etc/init.d/mosquitto start

#重启系统

sudo reboot

#测试MQTT服务是否安装正常,请使用我最新发布的MQTT服务测试页面:

http://www.hassmart.com/products/switches/#tab=mqtt-test

///---------安装hassio--推荐-------

curl -sL -o install.sh https://raw.githubusercontent.com/neroxps/hassio_install/master/install.sh

chmod a+x install.sh

./install.sh

//-------安装插件CD1插座------

hicomm_dc1m.py 放在/usr/share/hassio/homeassistant/custom_components/switch

目录下,

phicomm_dc1m.yaml放在/usr/share/hassio/homeassistant/packages目录下,

configuration.yaml 放在/usr/share/hassio/homeassistant目录下

把几个文件直接放TMP里执行下面命令。重启机器就Ok看了

mkdir /home/root/domoticz

mkdir /usr/share/hassio/homeassistant/custom_components

mkdir /usr/share/hassio/homeassistant/custom_components/switch

mkdir /usr/share/hassio/homeassistant/packages

cd /tmp

cp -r switch.py /usr/share/hassio/homeassistant/components/arduino

cp -r phicomm_dc1m.py /usr/share/hassio/homeassistant/custom_components/switch

cp -r phicomm_dc1m.yaml /usr/share/hassio/homeassistant/packages

cp -r configuration.yaml /usr/share/hassio/homeassistant

//-----删除hass-命令--

docker ps |grep "homeassistant/" |awk '{print $1}' | xargs docker rm -f

docker images |grep "homeassistant/" | awk '{print $3}'| xargs docker rmi

//----------------------------

---------domoticz里我的纬度---------

经度 105.110628

纬度 31.112097

https://api.caiyunapp.com/v2/Y2FpeXVuIGFuZHJpb2QgYXBp/105.110628,31.112097/realtime.json

https://api.caiyunapp.com/v2/TAkhjf8d1nlSlspN/104.686164,31.473364/realtime.json

https://api.caiyunapp.com/v2/Y2FpeXVuIGFuZHJpb2QgYXBp/104.6861,31.4733/realtime.json

caiyun_paraser.lua

本文使用emqx搭建mqtt: 官方地址传送门

1.查看openssl版本

一般情况,centos7版本为1.0.2,mqtt的框架emqx必须大于1.0.2,所以如果低于该版本请升级: centos升级openssl教程传送门

2.安装

3.查看防火墙

如果当前服务器打开了防火墙,需要将防火墙相应端口进行配置。

4.进入etc/emqx目录

5.修改配置文件emqx.conf

修改配置文件内容。

6.打开配置网页

登录网页端后台: http://xx.xx.xx.xx:18083/

7.配置网页打开插件emqx_auth_mnesia

网页端->插件->emqx_auth_mnesia->启动

8.配置mqtt用户名和密码

修改文件内容:

9.配置acl主题权限

修改文件内容:

10.重新加载acl配置文件

11.重新启动emqx


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/7971181.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-12
下一篇 2023-04-12

发表评论

登录后才能评论

评论列表(0条)

保存