天天看点

树莓派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

树莓派MQTT服务远程测试MQTT.fx

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

按q键退出。

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

  • 手动启动服务

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

树莓派MQTT服务远程测试MQTT.fx

2.2 本地测试

  • 订阅消息

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

树莓派MQTT服务远程测试MQTT.fx

等待接收消息。

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

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

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

树莓派MQTT服务远程测试MQTT.fx

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

树莓派MQTT服务远程测试MQTT.fx

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

树莓派MQTT服务远程测试MQTT.fx

3.3 设置MQTT.fx

点击齿轮图标开始设置。

  • MQTT Broker Profile Settings设置
树莓派MQTT服务远程测试MQTT.fx

点击Generate创建一个Client ID。

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

  • General设置
树莓派MQTT服务远程测试MQTT.fx
  • User Credentials设置
树莓派MQTT服务远程测试MQTT.fx

点击OK,创建Profile。

3.4 连接MQTT服务器

点击Connect连接MQTT服务器

树莓派MQTT服务远程测试MQTT.fx

连接成功。

3.5 用MQTTfx测试发布消息

  • 填写发布主题和要发布的消息
树莓派MQTT服务远程测试MQTT.fx

点击Publish。

  • 在树莓派上查看订阅的消息
树莓派MQTT服务远程测试MQTT.fx

3.6 用MQTTfx测试订阅消息

  • 选择Subscribe
树莓派MQTT服务远程测试MQTT.fx

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

  • 在树莓派发布消息消息

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

树莓派MQTT服务远程测试MQTT.fx
  • 查看接收到的消息
树莓派MQTT服务远程测试MQTT.fx

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

树莓派MQTT服务远程测试MQTT.fx

附录: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

# cafile:CA证书文件

# capath:CA证书目录

# certfile:PEM证书文件

# keyfile:PEM密钥文件

#cafile

#capath

#certfile

#keyfile

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

#require_certificate false

# 若require_certificate值为true,use_identity_as_username也必须为true

#use_identity_as_username false

# 启用PSK(Pre-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种日志模式:stdout、stderr、syslog、topic

# 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

# 桥接模式,目前有三种:automatic、lazy、once

#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