我是靠谱客的博主 负责胡萝卜,最近开发中收集的这篇文章主要介绍树莓派MQTT服务远程测试MQTT.fx,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

陈拓 2021.04.07/2021.04.07

 

1. 概述

在《树莓派安装Mosquitto MQTT服务》

https://zhuanlan.zhihu.com/p/359395794

https://blog.csdn.net/chentuo2000?spm=1000.2115.3001.5343

一文中我们已经在树莓派上安装了mosquitto MQTT服务,并进行了本地测试。在此基础上,本文进行远程测试。

远程测试在PC上进行,需要安装工具MQTTfx。安装见《MQTTfx连接物联网云平台》

https://zhuanlan.zhihu.com/p/101104351

https://blog.csdn.net/chentuo2000/article/details/104313968

2. 本地测试

2.1 启动mosquitto

  • 查看mosquitto状态

sudo service mosquitto status

可以看到服务已经启动了:active (running)

q键退出。

如果服务未启动:inactive (dead),可以手动启动服务。

  • 手动启动服务

mosquitto -c /etc/mosquitto/mosquitto.conf -d

2.2 本地测试

  • 订阅消息

mosquitto_sub -p 1883 -u ct -P xxxxxxxx -t emqtt/my_topic

等待接收消息。

emqtt/my_topic是我订阅的消息主题,随便起一个主题名字,只要和下面发布的主题名字一致就行。

  • 再打开1个终端发布消息

mosquitto_pub -p 1883 -u ct -P xxxxxxxx -t emqtt/my_topic -m "Hello!"

查看订阅端接收到的消息:

3. 用MQTT.fx远程测试

3.1 安装MQTT.fx

见《MQTTfx连接物联网云平台》

https://zhuanlan.zhihu.com/p/101104351

https://blog.csdn.net/chentuo2000/article/details/104313968

3.2 打开MQTT.fx

3.3 设置MQTT.fx

点击齿轮图标开始设置。

  • MQTT Broker Profile Settings设置

点击Generate创建一个Client ID

如果你有IP地址,替换raspberrypi.local。

  • General设置

  • User Credentials设置

点击OK,创建Profile

3.4 连接MQTT服务器

点击Connect连接MQTT服务器

连接成功。

3.5 MQTTfx测试发布消息

  • 填写发布主题和要发布的消息

点击Publish

  • 在树莓派上查看订阅的消息

3.6 MQTTfx测试订阅消息

  • 选择Subscribe

填写主题,点击Subscribe,等待接收消息。

  • 在树莓派发布消息消息

mosquitto_pub -p 1883 -u ct -P xxxxxxxx -t emqtt/my_topic -m "This mesage is published by Raspberry pi."

  • 查看接收到的消息

树莓派的订阅窗口也同时收到消息:

 

附录:Mosquitto的配置参数说明

# =================================================================

# General configuration

# =================================================================

 

# 客户端心跳的间隔时间

#retry_interval 20

 

# 系统状态的刷新时间

#sys_interval 10

 

# 系统资源的回收时间,0表示尽快处理

#store_clean_interval 10

 

# 服务进程的PID

#pid_file /var/run/mosquitto.pid

 

# 服务进程的系统用户

#user mosquitto

 

# 客户端心跳消息的最大并发数

#max_inflight_messages 10

 

# 客户端心跳消息缓存队列

#max_queued_messages 100

 

# 用于设置客户端长连接的过期时间,默认永不过期

#persistent_client_expiration

 

# =================================================================

# Default listener

# =================================================================

 

# 服务绑定的IP地址

#bind_address

 

# 服务绑定的端口号

#port 1883

 

# 允许的最大连接数,-1表示没有限制

#max_connections -1

 

# cafileCA证书文件

# capathCA证书目录

# certfilePEM证书文件

# keyfilePEM密钥文件

#cafile

#capath

#certfile

#keyfile

 

# 必须提供证书以保证数据安全性

#require_certificate false

 

# require_certificate值为trueuse_identity_as_username也必须为true

#use_identity_as_username false

 

# 启用PSKPre-shared-key)支持

#psk_hint

 

# SSL/TSL加密算法,可以使用“openssl ciphers”命令获取

# as the output of that command.

#ciphers

 

# =================================================================

# Persistence

# =================================================================

 

# 消息自动保存的间隔时间

#autosave_interval 1800

 

# 消息自动保存功能的开关

#autosave_on_changes false

 

# 持久化功能的开关

persistence true

 

# 持久化DB文件

#persistence_file mosquitto.db

 

# 持久化DB文件目录

#persistence_location /var/lib/mosquitto/

 

# =================================================================

# Logging

# =================================================================

 

# 4种日志模式:stdoutstderrsyslogtopic

# none 则表示不记日志,此配置可以提升些许性能

log_dest none

 

# 选择日志的级别(可设置多项)

#log_type error

#log_type warning

#log_type notice

#log_type information

 

# 是否记录客户端连接信息

#connection_messages true

 

# 是否记录日志时间

#log_timestamp true

 

# =================================================================

# Security

# =================================================================

 

# 客户端ID的前缀限制,可用于保证安全性

#clientid_prefixes

 

# 允许匿名用户

#allow_anonymous true

 

# 用户/密码文件,默认格式:username:password

#password_file

 

# PSK格式密码文件,默认格式:identity:key

#psk_file

 

# pattern write sensor/%u/data

# ACL权限配置,常用语法如下:

# 用户限制:user <username>

# 话题限制:topic [read|write] <topic>

# 正则限制:pattern write sensor/%u/data

#acl_file

 

# =================================================================

# Bridges

# =================================================================

 

# 允许服务之间使用“桥接”模式(可用于分布式部署)

#connection <name>

#address <host>[:<port>]

#topic <topic> [[[out | in | both] qos-level] local-prefix remote-prefix]

 

# 设置桥接的客户端ID

#clientid

 

# 桥接断开时,是否清除远程服务器中的消息

#cleansession false

 

# 是否发布桥接的状态信息

#notifications true

 

# 设置桥接模式下,消息将会发布到的话题地址

# $SYS/broker/connection/<clientid>/state

#notification_topic

 

# 设置桥接的keepalive数值

#keepalive_interval 60

 

# 桥接模式,目前有三种:automaticlazyonce

#start_type automatic

 

# 桥接模式automatic的超时时间

#restart_timeout 30

 

# 桥接模式lazy的超时时间

#idle_timeout 60

 

# 桥接客户端的用户名

#username

 

# 桥接客户端的密码

#password

 

# bridge_cafile:桥接客户端的CA证书文件

# bridge_capath:桥接客户端的CA证书目录

# bridge_certfile:桥接客户端的PEM证书文件

# bridge_keyfile:桥接客户端的PEM密钥文件

#bridge_cafile

#bridge_capath

#bridge_certfile

#bridge_keyfile

 

# 自己的配置可以放到以下目录中

include_dir /etc/mosquitto/conf.d

 

最后

以上就是负责胡萝卜为你收集整理的树莓派MQTT服务远程测试MQTT.fx的全部内容,希望文章能够帮你解决树莓派MQTT服务远程测试MQTT.fx所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(56)

评论列表共有 0 条评论

立即
投稿
返回
顶部