MQTT-java使用说明

2023-11-17

MQTT-java使用说明

本文的资料下载:
链接:https://pan.baidu.com/s/1OCfsQ_NqcehKy86kYkA-wg?pwd=1234
提取码:1234

MQTT基本介绍

MQTT是一个客户端服务端架构的发布/订阅模式的消息传输协议。

特点

  1. 易于实现
  2. 数据传输的服务质量可控
  3. 占用带宽小
  4. 传输数据不可预知
  5. 设备连接状态可知

主要版本

  • MQTT3.1.1(较为通用)
  • MQTT5

发布/订阅特性

  1. 相互独立,不需要知道有几个设备订阅了这个主题。
  2. 空间可分离,只要有互联网或者局域网就可以。
  3. 时间可异步

连接MQTT服务端

客户端发送CONNECT(报文)做请求连接

服务端回复CONNACK确认连接

CONNECT(报文)

名称 内容
clientId(distinct) “client-1”
cleanSession(判定是不是一个重要客户端) true
username(可选) “hans”
password(可选) “letmein”
lastWillTopic(可选) “/hans/will”
lastWillQos(可选) 2
lastMessage(可选) “unexpected exit”
lastWillRetain(可选) false
keepAlive 60
clientId

客户端ID,每个客户端的ID是唯一的(distinct)。

cleanSession

用来标志是不是一个重要的客户端,如果是的话,标志为false。

clean清除,Session回话,就是不保存会话,设置为false,就是保存会话,如果客户端没有确认收到信息,那么就用保存的会话信息继续发送,直到接收成功。

设置为false 的时候,要把Qos>0。

keepAlive

心跳机制

要求客户端定时发送信息给服务端,告诉服务端客户端活着。

单位s,指定时多长时间发送一次“活着的”信息给服务端。

Qos
Qos 含义
0 At most once,发送一次消息后,就不再关心它有没有发送到对方,也不设置任何重发机制
1 At least once,包含了简单的重发机制,Sender发送信息之后等待接收者的ACK,如果没收到ACK则重新发送信息。这种模式能保证信息至少能到达一次,但无法保证消息重复。
2 Exactly once,设计了略为复杂的重发和重复消息发现机制,保证消息到达对方并且严格只到达一次。

与计算机网络中的可靠传输和不可靠传输相似。

CONNACK

名称 内容
sessionPersent(当前会话) true
returnCode(连接返回码) 0
returnCode连接返回码返回值含义
返回码 返回码描述
0 成功连接
1 连接被服务端拒绝,原因是不支持客户端的MQTT协议版本
2 连接被服务端拒绝,原因是不支持客户端标识符的编码。 可能造成此原因的是客户端标识符编码是UTF-8,但是服务端不允许使用此编码。
3 连接被服务端拒绝,原因是服务端不可用。 即,网络连接已经建立,但MQTT服务不可用。
4 连接被服务端拒绝,原因是用户名或密码无效。
5 连接被服务端拒绝,原因是客户端未被授权连接到此服务端。
sessionPersent(当前会话)

上次服务器想发给客户端的信息,如果发送给客户端,客户端没有确认或者客户端没有收到,那么这个标志为true。

申请MQTT服务器-EMQX

EMQX免费申请MQTT服务器网址:

https://www.emqx.com/zh/cloud

点免费试用

image-20220327193811163

注册一下

image-20220327193952487

选择基础版,高级版的用数据集成里面的东西需要做VPC链接,比较麻烦。

image-20220327194341947

这些默认就行,自己想换个就换个选项,然后下一步

image-20220327194544942

立即部署

image-20220327194646350

第一次创建的时候,只有左边红框里面的东西,显示正在创建实例,这个过程比较费劲

image-20220327194818620

这个时候可以先来安装一下MQTTX这个软件,这个软件是由EMQX公司开发的

image-20220327195211621

安装的时候,就一直下一步就行,可能会出现电脑警告认为这个是有病毒的软件,忽略就行,没毒。

同时我们还需要安装一下mosquitto。

image-20220327214547548

打开以后是这样的:

image-20220327201322988

创建实例结束后就是这样:

image-20220327195953670

点击它

image-20220327200036205

这里呢,我们看一下这几个的含义

连接地址:这个就是服务器的地址

连接端口:11066(mqtt), 12095(mqtts), 13788(ws), 14120(wss)

mqtt协议,用这个11066(mqtt)

mqtt+TLS,用这个12095(mqtts)

网页端的不加密传输,用这个13788(ws)

网页端的加密传输,用这个14120(wss)

类似于http和https。这几个端口不一定,每个账号自己创建完后的端口号可能不一样,要看自己创建完的是多少。

连接测试MQTT服务器

首先要添加一个认证,就是创建一个用户和密码。这个虽然在协议里面不是必须的,但是在这个服务器里面是必须的。

选左边的认证,然后输入用户名和密码,这里为了测试方便,我设置的用户名是test,密码是123456,然后点添加。

image-20220327201747841

添加完以后:

image-20220327201908502

然后可以做在线调试,选左边的在线调试就可以

image-20220327202120757

连接地址就是创建的服务器地址,不需要手动输入,端口也是选好的mqtt的那个。

然后输入用户名,密码和连接名称,连接名称随便起一个就行,点连接。

image-20220327202407061

这里显示的还有客户端ID,这个需要唯一标识,之前CONNECT(报文)那里提到过。Keepalive是心跳机制里面的每个多少秒发送一次信号,确认客户端还在连接着。

连接后显示如下:

image-20220327212039822

我们将主题设为testtopic/1,Qos为0然后订阅。

image-20220327212212765

下面发布的主题也设为testtopic/1,Qos为0,然后点发布。

image-20220327212302430

右边的是我们发送的,左边的是收到的消息。

这样就测试成功了。

这一段也可以跟着这个官方的B站视频来做,视频链接:

https://www.bilibili.com/video/BV1hi4y1Z7Lr?spm_id_from=333.999.0.0

MQQTX的使用也差不多,输入服务器地址和端口号,用户和密码就能使用。

使用 Java SDK 连接到部署

下载java连接示例代码

文件里面也是有的,在这个压缩包里面,解压以后有个mqtt-client-Java的文件夹,这个就是我们要用的代码。

image-20220327214821622

或者可以从网站上下载https://github.com/emqx/MQTT-Client-Examples

image-20220327214958545

部署的教程,EMQX也提供了一个文档说明,网址如下:

https://docs.emqx.com/zh/cloud/latest/connect_to_deployments/java_sdk.html#%E5%89%8D%E6%8F%90%E6%9D%A1%E4%BB%B6

image-20220327215203004

我们就直接在intellij IDEA中打开这个项目文件,然后进行配置修改就好。他是用Maven来做的配置,从头开始建,没有Maven的知识,不太容易。

改错

下面这一部分,是根据这个博客

https://blog.csdn.net/u014677702/article/details/86013565

打开以后,会发现有很多的红色报错,点击右上角的项目结构

image-20220327215926064

把java11换成java1.8,然后确定就好了。

image-20220327220106346

然后在SampleCallback这个里面

image-20220327220234531

这里根据提示,改一下就行。

image-20220327220335778

然后,安装一下Maven,下面这些按照这个博客安装的

https://blog.csdn.net/weixin_42893085/article/details/105539472

下载安装maven:

http://maven.apache.org/download.cgi

image-20220327222112240

下载这个,或者我在文件夹里面也放了这个包

image-20220327222202732

把它解压到C盘、D盘等盘里面就行。

这里我就放到了D盘

然后配置环境变量,右击此电脑,点属性

image-20220327222337214

然后划到底,打开高级系统设置

image-20220327222513167

打开环境变量

image-20220327222540470

在这里新建一个

image-20220327222655107

变量名为

MAVEN_HOME

变量值为

自己解压的文件夹目录(我的是D:\apache-maven-3.8.5)

目录下面需要有bin文件夹

image-20220327222824827

输入完成,确认。

image-20220327222926992

然后在Path这个里面选择编辑

image-20220327223152686

新加入一条记录

%MAVEN_HOME%\bin

image-20220327223305794

全部确定退出环境变量设置后,进行测试,WIN+R,输入cmd,打开终端。

echo %JAVA_HOME%
mvn -version

image-20220327223555035

这样Maven已经在计算机上安装好了

希望更改Maven在本地存放依赖地址的,看下面这个视频更改,不改的话,默认存放在C盘,不怎么使用的话,放C盘也行。

https://www.bilibili.com/video/BV1Fz4y167p5?p=5

然后配置intellij,让intellij知道Maven这个东西。下面操作是根据这个博客来的:

https://blog.csdn.net/lyg9966/article/details/105904175

在解压后的文件里面,打开conf,里面有个settings.xml,打开这个文件。

image-20220327224318520

在里面,加入下面这些

 <!-- 更换阿里镜像,加快依赖下载 -->
     <mirror>
    <id>aliyunmaven</id>
    <mirrorOf>central</mirrorOf>
    <name>central</name>
    <url>https://maven.aliyun.com/repository/central</url>
    </mirror>

image-20220327224452050

然后在Intellij IDEA设置

image-20220327224659416

在这个地方填入

-Dmaven.wagon.http.ssl.insecure=true -Dmaven.wagon.http.ssl.allowall=true -Dmaven.wagon.http.ssl.ignore.validity.dates=true

image-20220327224811303

这个博客里面还说要删除plugin,我这里没有报这个错误,有需要的看原博客。

构建,然后运行就可以。当然要是想要mqtt通信的效果,还需要在代码里面将之前的服务器信息进行配置。

java代码配置mqtt服务

image-20220327225453889

需要配置这几个地方

		String topic = "testtopic/1";//这个是刚才发布的那个话题名
        String content = "Hello World";//这个是要发送的信息
        int qos = 2;
        String broker = "tcp://de1f21c0.cn-shenzhen.emqx.cloud:11066";//服务器地址+端口号
        String clientId = MqttClient.generateClientId();
        MemoryPersistence persistence = new MemoryPersistence();
        MqttConnectOptions connOpts = new MqttConnectOptions();
        connOpts.setUserName("test");//用户名
        connOpts.setPassword("123456".toCharArray());//密码

运行以后

image-20220327225720773

在网站里面查看或者在MQTTX中订阅了这个话题的话,就能看到

image-20220327225814260

image-20220327230016156

MQTT-java模拟单车扫码开锁

在文件夹里面有源代码mqtt-java-bic-phone

image-20220327233047407

直接用Intellij打开就行。这是代码结构:

image-20220327230354006

这里面实现了模拟手机和单车两个终端,手机发送SendJson的请求,然后服务器使用EMQX里面数据集成里面消息重新发布功能,

image-20220327230507670

在这里面设置规则

SELECT
  payload.bicid as bicid,    payload.bicstate as bicstate,    payload.lockstate as lockstate,    payload.request as request,    payload.userid as userid
FROM
  "testtopic/3"
WHERE
  bicstate = true
  and lockstate = false
  and request = 1

当bicstate的状态为true(车是好的),lockstate为false(车锁关着),request为1(请求开锁)的时候,就对testtopic/4发送RecJson格式的信息。

image-20220327231410745

发送车子ID,用户ID和开锁请求lock为true,来请求车子开锁。

{"bicid":"${bicid}","userid":"${userid}","lock":"true"}

image-20220327231434010

这些怎么配置,详情见帮助里面的数据集成里面的规则管理

https://docs.emqx.com/zh/cloud/latest/rule_engine/rules.html#%E5%88%9B%E5%BB%BA%E8%A7%84%E5%88%99

image-20220327231558976

注意:我们这里用的不是专业版,而是基础版,所以不需要进行VPC设置。

通过规则设置,简单的实现了服务器处理数据,并根据数据处理结果进行数据转发,发送不同数据的操作。

当车子收到开锁请求,并且开锁以后,对testtopic/3发送”锁已打开“,这时手机就会收到这条信息,知道锁已打开。

image-20220327232102304

先运行MqttRec(模拟单车)再运行MqttSample(模拟手机),就会看到下面的结果。

image-20220327232338443

image-20220327232454862

有时候运行的时候,会显示上次已经发送接收到了的信息,这个可能是因为qos的设置问题,具体原因不清楚。

所有代码都有注释,具体代码实现请看文件夹里面的代码。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

MQTT-java使用说明 的相关文章

  • 图像处理之-----插值算法

    插值算法是图像处理中最基本的算法 首先我们先了解一下什么是插值算法 以及插值算法在图像处理过程中的应用 1 什么是插值 Interpolation is a method of constructing new data points wi
  • Redis 密码设置和查看密码

    Redis 密码设置和查看密码 redis没有实现访问控制这个功能 但是它提供了一个轻量级的认证方式 可以编辑redis conf配置来启用认证 1 初始化Redis密码 在配置文件中有个参数 requirepass 这个就是配置redis

随机推荐

  • Python软件开发之需求实现:数据结构、数据类型。自动化软件测试必会

    一 有这样的一个需求 判断学生成绩是否及格 二 拿到这样的一个需求如何进行需求分析呢 做为测试人员 我们只有明确需求后 才不容易漏测 需求分析阶段 一 看到这样的一句话之后我们有几个问题需求和产品经理确认的 1 什么样的算及格 60 70分
  • Spark 启动集群 Master 正常启动 Worker 不启动

    在学习spark过程中遇到的问题 做下记录 这个问题网上出现的不再少数 出现问题的原因也是各不相同 并且没有一个人的问题和我完全一样 我高兴得都快哭了 顺着大家的思路 尝试了两个多小时才搞明白 问题的根源大多都在于 hostname 的配置
  • C++ STL - vector 模拟实现+解析迭代器

    目录 vector使用 vector模拟实现 vector实现解析 memcpy进行元素拷贝问题 扩容问题 vector迭代器解析 vector迭代器失效问题 1 示例一 一个典型的迭代器失效bug insert实现 2 示例二 inser
  • 记录一些可能会用到资料

    1 win11子系统WSL修改用户密码 以管理员身份打开 PowerShell 输入命令 wsl exe user root passwd root 修改 root 用户密码 2 layDate控件在页面高度不够的情况下闪退 在laydat
  • 8x8LED点阵

    点量这个只需要把9高电平 13低电平就可以了 共阳极点阵 行线是led的正极 列线是led的列线 左上角点亮 显示多个灯是动态扫描的 一个一个显示的 然后间隔速度要快就可以造成显示 点阵由两篇74Hc595级联在一起驱动的 只需要三个io口
  • matplotlib输出图形到网页_Python实操:手把手教你用Matplotlib把数据画出来

    导读 获取数据之后 而不知道如何查看数据 用途还是有限的 幸好 我们有Matplotlib Matplotlib 是基于 NumPy 数组构建的多平台数据可视化库 它是John Hunter 在2002年构想的 原本的设计是给 IPytho
  • 【LeetCode与《代码随想录》】哈希表篇:做题笔记与总结-JavaScript版

    文章目录 代码随想录 主要题目 242 有效的字母异位词 349 两个数组的交集 202 快乐数 1 两数之和 经典哈希 454 四数相加 II 15 三数之和 双指针 18 四数之和 双指针 相关题目 383 赎金信 49 字母异位词分组
  • mnist数据集之自己写的数字

    这是我自己用画图3D写的数字0 9 然后又把它们修改成了28 28像素的格式 并经过测试后输出了预测值 不知道怎么搞得 顺序打乱了 这是我测试后的结果 要加油哦
  • C语言——执行创建多个文件同时写入内容

    代码 include
  • Python3, 多种方法实现文件/目录的监听,只想说一个字:泰裤辣。

    多种方法实现文件 目录监听 1 引言 2 代码实战 2 1 os模块 2 2 watchdog库 2 2 1 安装 2 2 2 示例 2 3 inotify 2 3 1 安装 2 3 2 示例 3 总结 1 引言 小屌丝 鱼哥 帮我看下这段
  • 说透 Nacos 一致性协议

    1 Nacos 致性协议 1 1 为什么 Nacos 需要 致性协议 Nacos尽可能减少用户部署以及运维成本 做到用户只需要 个程序包 就快速单机模式启动 Nacos 或集群模式启动 Nacos 而 Nacos 是 个需要存储数据的组件
  • java基础—HashMap实现原理,如何保证HashMap的线程安全

    在多线程条件下 容易导致死循环 具体表现为CPU使用率100 因此多线程环境下保证 HashMap 的线程安全性 主要有如下几种方法 1 替换成Hashtable Hashtable通过对整个表上锁实现线程安全 因此效率比较低 2 使用Co
  • 台式计算机的配置怎么看,台式电脑配置怎么看

    电脑的性能 价格决定于电脑的配置 很多人电脑新手在购买电脑的时候对电脑配置的相关情况不太了解 导致新买的电脑频频出问题 所以了解自己电脑配置是很重要的 这里我们就简单的来说说台式电脑配置怎么看 电脑配置一般CPU 显卡 主板 内存 硬盘 显
  • lambda表达式二之Stream流

    Stream流 是数据渠道 用于操作数据源 集合 数组等 所生成的元素序列 集合讲的是数据 流讲的是计算 Stream自己不会存储元素 Stream不会改变源对象 会返回一个持有结果的新Stream Stream操作是延迟执行的 意味着会等
  • LeetCode312. 戳气球 (分治,记忆化搜索,动态规划)

    LeetCode312 戳气球 解题思路 记忆化搜索 动态规划 解题思路 官方题解 参考题解 核心思想 由于戳气球的操作会导致两个气球从不相邻变成相邻 使得后续操作难以处理 于是我们倒过来看这些操作 将全过程看成每次添加一个气球 solve
  • CMake入门实践(一) 什么是cmake

    一 CMake简介 CMake是一个跨平台的安装 编译 工具 可以用简单的语句来描述所有平台的安装 编译过程 他能够输出各种各样的makefile或者project文件 能测试编译器所支持的C 特性 类似UNIX下的automake 只是
  • mac AE 快捷键

    项目窗口 新项目 Ctrl Alt N 打开项目 Ctrl O 打开项目时只打开项目窗口 按住Shift键 打开上次打开的项目 Ctrl Alt Shift P 保存项目 Ctrl S 选择上一子项 上箭头 选择下一子项 下箭头 打开选择的
  • Flink + Hudi 实现多流拼接(大宽表)

    1 背景 经典场景 Flink 侧实现 业务侧通常会基于实时计算引擎在流上做多个数据源的 JOIN 产出这个宽表 但这种解决方案在实践中面临较多挑战 主要可分为以下两种情况 维表 JOIN 场景挑战 指标数据与维度数据进行关联 其中维度数据
  • .net 配置网关(使用Ocelot)

    本文演示一个最简单的demo 来模拟如何通过网关来访问服务 而不是直接访问服务 创建三个asp net core web api项目 一个作为网关 两个作为服务 分别配置项目的访问路径 网关的项目使用https localhost 5001
  • MQTT-java使用说明

    MQTT java使用说明 本文的资料下载 链接 https pan baidu com s 1OCfsQ NqcehKy86kYkA wg pwd 1234 提取码 1234 MQTT基本介绍 MQTT是一个客户端服务端架构的发布 订阅模