前言

随着物联网(IoT)技术的迅猛发展,MQTT(消息队列遥测传输)协议凭借其轻量级和高效性,已成为众多物联网应用的首选通信标准。

MQTTnet 作为一个高性能的 .NET 开源库,为 .NET 平台上的 MQTT 客户端与服务器开发提供了强大的支持。

本文将全面介绍 MQTTnet 的核心功能、显著优势及其广泛的应用场景,帮助我们更好地利用工具提升物联网项目的效率与可靠性。

项目介绍

MQTTnet 是一个跨平台、高性能和开源的 MQTT 客户端库和服务端实现,是 .NET 平台上主流的 MQTT 实现之一。

基于 MQTTnet,用户可以方便地在 .NET 平台上集成 MQTT 功能,实现 MQTT 协议的消息传输等功能。

它支持 .NET Standard 2.0 及以上版本,可在多版本 .NET 平台上运行,包括 .NET Framework、.NET Core 和 Xamarin。

MQTTnet 提供同步和异步操作、内置日志记录、QoS 支持等功能,并包含客户端和服务器组件,支持 MQTT 协议从 3.1.1 到 5.0 的版本。

功能说明

客户端功能

MQTTnet 提供了强大的客户端功能,能够轻松连接到 MQTT 服务器并进行通信。

其主要特性包括:

  • 连接管理: 支持与单个或多个服务器建立和管理连接。

  • 消息发布与订阅: 支持不同 QoS 级别的消息发布和订阅,确保可靠传输。

  • 保持活动: 自动管理心跳,保持连接活跃。

  • 重连机制: 自动重连,确保通信稳定。

服务器功能

MQTTnet 同时支持构建 MQTT 服务器,可以创建自定义的 MQTT 服务。

其主要特性包括:

  • 连接管理: 支持大量并发连接。

  • 消息路由: 根据订阅规则将消息路由到相应客户端。

  • 安全机制: 支持多种身份验证和授权机制。

  • 日志与监控: 提供日志记录和监控功能,便于问题排查。

功能特点

1、客户端和服务器支持: MQTTnet 同时提供了客户端和服务器实现,便于构建完整的 MQTT 通信系统。

2、高性能: 采用异步编程模型,确保高效的消息处理和传输。

3、跨平台兼容性: 兼容多种 .NET Framework 版本,包括 .NET Core 及 .NET 5/6/7,支持不同操作系统和 CPU 架构。 易于使用: 提供简洁的 API,方便开发者集成 MQTT 功能。

4、支持 MQTT v5: 支持 MQTT 最新版本 5 及其所有特性。

5、可扩展性: 设计灵活,允许自定义和扩展功能。

6、安全性: 支持 SSL/TLS 加密,保障通信安全。

7、轻量级: 体积小巧,适用于资源受限的 IoT 设备。

应用场景

MQTTnet 可用于构建多种基于 MQTT 协议的应用程序,包括:

  • 物联网 (IoT): 适用于连接资源受限的设备,如传感器和执行器。
  • 车联网: 用于连接车载设备并收集实时数据。
  • 工业自动化: 用于连接工业控制系统和设备。

使用方法

1、安装 MQTTnet

需要将 MQTTnet 库添加到项目中,使用 NuGet 包管理器进行安装:

Install-Package MQTTnet

或者使用.NET CLI

dotnet add package MQTTnet

2、服务端代码

服务端代码编写,具体步骤可以参考以下步骤。

  • 1、初始化 MQTT 服务器

创建一个 MQTT 服务器工厂实例,并使用它创建一个服务器。

using MQTTnet.Server;
var factory = new MqttFactory();
var mqttServer = factory.CreateMqttServer();
  • 2、配置 MQTT 服务器选项

配置服务器选项,例如默认端口等。

var options = new MqttServerOptionsBuilder()
.WithDefaultEndpointPort(1883)
.Build();
  • 3、启动 MQTT 服务器
await mqttServer.StartAsync(options
  • 4、处理客户端连接

为服务器的 ClientConnectedHandler 和 ClientDisconnectedHandler 事件添加处理程序,以处理客户端连接和断开。

mqttServer.ClientConnectedHandler = new MqttServerClientConnectedHandlerDelegate(e =>
{
Console.WriteLine($"客户端已连接: {e.ClientId}");
}); mqttServer.ClientDisconnectedHandler = new MqttServerClientDisconnectedHandlerDelegate(e =>
{
Console.WriteLine($"客户端已断开连接: {e.ClientId}");
});
  • 5、处理消息

为服务器的 ApplicationMessageReceivedHandler 事件添加处理程序,以处理接收到的消息。

mqttServer.ApplicationMessageReceivedHandler = new MqttApplicationMessageReceivedHandlerDelegate(e =>
{
Console.WriteLine($"接收消息: {Encoding.UTF8.GetString(e.ApplicationMessage.Payload)} from client: {e.ClientId}");
});
  • 6、停止 MQTT 服务器

完成通信消息后,需要停止服务器。

await mqttServer.StopAsync();

3、客户端代码

使用 MQTTnet创建 MQTT 客户端,具体步骤可以参下面代码。

  • 1、初始化 MQTT 客户端

创建一个 MQTT 客户端工厂实例,并使用它创建一个客户端。

using MQTTnet;
using MQTTnet.Client;
using MQTTnet.Client.Options; var factory = new MqttFactory();
var mqttClient = factory.CreateMqttClient();
  • 2、配置 MQTT 客户端选项

配置客户端连接选项,例如服务器地址和端口。

var options = new MqttClientOptionsBuilder()
.WithClientId("客户端ID")
.WithTcpServer("mqtt服务器地址", 1883)
.WithCleanSession()
.Build();
  • 3、连接到 MQTT 服务器

使用配置的选项连接到 MQTT 服务器。

await mqttClient.ConnectAsync(options, CancellationToken.None);
  • 4、订阅主题

连接成功后,可以订阅一个或多个主题。

await mqttClient.SubscribeAsync(new MqttTopicFilterBuilder()
.WithTopic("test/topic")
.Build());
  • 5、接收消息

为客户端的 ApplicationMessageReceivedHandler 事件添加处理程序,以接收消息:

mqttClient.UseApplicationMessageReceivedHandler(e =>
{
Console.WriteLine($"接收消息: {Encoding.UTF8.GetString(e.ApplicationMessage.Payload)}");
});
  • 6、发布消息

可以发布消息到指定的主题。

var message = new MqttApplicationMessageBuilder()
.WithTopic("test/topic")
.WithPayload("您好 MQTT")
.WithQualityOfServiceLevel(MQTTnet.Protocol.MqttQualityOfServiceLevel.AtLeastOnce)
.Build(); await mqttClient.PublishAsync(message, CancellationToken.None);
  • 7、断开连接

完成消息发送后,断开与服务器的连接。

await mqttClient.DisconnectAsync();

通过上述步骤,我们实现了基本的发布与订阅功能:发布者将消息发布到 "test/Topic" 主题,订阅者订阅了同一主题,并在收到新消息时将其打印出来。

虽然是一个简单示例,但在实际项目中,可以根据具体需求进一步扩展功能,例如添加异常处理等。

项目地址

Github: https://github.com/dotnet/MQTTnet

官网:https://mqtt.org/

总结

本文介绍了 MQTT 的相关信息,并展示了如何在.NET 中进行基本的使用。

MQTT 还有许多高级功能,大家可以通过查阅 MQTTnet 的官方 API 文档进一步学习和使用其它功能。

最后

如果你觉得这篇文章对你有帮助,不妨点个赞支持一下!你的支持是我继续分享知识的动力。如果有任何疑问或需要进一步的帮助,欢迎随时留言。

也可以加入微信公众号[DotNet技术匠] 社区,与其他热爱技术的同行一起交流心得,共同成长!优秀是一种习惯,欢迎大家留言学习!

.NET 开源高性能 MQTT 类库的更多相关文章

  1. 【开源】MQTT推送服务器——zer0MqttServer(Java编写)

    目录 说明 功能 如何使用 参考帮助 说明 重要的放前面:V1.0版本是一个非常基础的版本,除了完整的MQTT协议实现外,其他功能什么都没做. MQTT 协议是 IBM 开发的即时通讯协议,相对于 I ...

  2. @ResponseBody 返回json字符串的核心类是org.springframework.http.converter.json.MappingJacksonHttpMessageConverter,它使用了Jackson 这个开源的第三方类库。主要是以下两个jar包:jackson-core-asl-1.6.4.jar;jackson-mapper-asl-1.6.4.jar

    @ResponseBody 返回json字符串的核心类是org.springframework.http.converter.json.MappingJacksonHttpMessageConvert ...

  3. Apache—dbutils开源JDBC工具类库简介

    Apache—dbutils开源JDBC工具类库简介 一.前言 commons-dbutils 是 Apache 组织提供的一个开源 JDBC工具类库,它是对JDBC的简单封装,学习成本极低,并且使用 ...

  4. FastDFS是使用c语言编写的开源高性能分布式文件系统

    FastDFS是什么 FastDFS是使用c语言编写的开源高性能分布式文件系统 是由淘宝开发平台部资深架构师余庆开发,FastDFS孵化平台板块 他对文件进行管理,功能包括文件存储,文件同步,文件访问 ...

  5. golang开发:类库篇(一) Zap高性能日志类库的使用

    为什么要用zap来写日志 原来是写PHP的,一直用的error_log,第一次写Go项目的时候,还真不知道该怎么写日志,后来就按照PHP的写法自己不成规范的捣鼓写.去了新公司之后,发现用的是zap.后 ...

  6. Dapeng框架-开源高性能分布式微服务框架

    我们公司性质是新零售,公司也有专门的框架组.这群大牛自己开发了一整套分布式微服务框架.我们也在使用这套框架,有很多心得体会. 该框架既Dapeng也!开源github地址:https://github ...

  7. NTCPMSG 开源高性能TCP消息发送组件

    https://www.cnblogs.com/eaglet/archive/2013/01/07/2849010.html 目前的.net 架构下缺乏高效的TCP消息发送组件,而这种组件是构建高性能 ...

  8. MQTT的学习研究(十)【转】mosquitto——一个开源的mqtt代理

    MQTT(MQ Telemetry Transport),消息队列遥测传输协议,轻量级的发布/订阅协议,适用于一些条件比较苛刻的环境,进行低带宽.不可靠或间歇性的通信.值得一提的是mqtt提供三种不同 ...

  9. [.NET 开源] 高性能的 Swifter.MessagePack 已发布,并附带新版本的 Swifter.Json 和 Swifter.Data。

    抱歉各位朋友,由于各种私事公事,本应该在 19 年底发布的 Swifter.MessagePack 库延迟了这么久才发布,我深感抱歉. MsgPack 简介 MsgPack 一种非常轻巧的二进制数据交 ...

  10. .NET开源高性能Socket通信中间件Helios介绍及演示

    一:Helios是什么 Helios是一套高性能的Socket通信中间件,使用C#编写.Helios的开发受到Netty的启发,使用非阻塞的事件驱动模型架构来实现高并发高吞吐量.Helios为我们大大 ...

随机推荐

  1. Jmeter函数助手41-unescapeHtml

    unescapeHtml函数用于将HTML转义过的字符串反转义为Unicode字符串. String to unescape:填入字符 1.escapeHtml函数是将字符进行HTML转义,unesc ...

  2. 【Vue】el-select 数据过多替代方案

    一.需求问题: 一开始就考虑使用简单el-select选取数据,但是后面数据量增多, 超过一千条开始,组件会很卡不好用,第二个是接口也慢了 数据量多的话是有一个filterable做支持了,可以输入关 ...

  3. 【Oracle】SQL笔记

    与MySQL的区分 https://www.cnblogs.com/bailing80/p/11440927.html 获取当前系统时间 -- 查询当前系统时间,DUAL为一张临时表 SELECT S ...

  4. 【RabbitMQ】12 日志监控 & 消息追踪

    一.日志和监控 RabbitMQ日志存放目录 [root@localhost ~]# ll /var/log/rabbitmq/ 总用量 176 -rw-r-----. 1 rabbitmq rabb ...

  5. 华为超算平台git、cmake、wget、curl报错:SSLv3_client_method version OPENSSL_1_1_0 not defined in file libssl.so.1.1 with link time reference——解决方法

    最近在使用超算平台时报错,不管是git.cmake.wget.curl中的哪个都报错,大致错误: /usr/bin/cmake3: relocation error: /usr/lib64/libcu ...

  6. SMU Summer 2023 Contest Round 2

    SMU Summer 2023 Contest Round 2 A. Treasure Hunt 当\(x1 - x2\)的差值与\(y1-y2\)的差值都能被\(x,y\)整除时,且商之和为2的倍数 ...

  7. .NET 9发布的最后一个预览版Preview 7, 下个月发布RC

    微软在2024年8月9日 发布了.NET 9 Preview 7[1],这是它在2024 年 11 月 12 日 RTM 之前进入发布候选阶段之前的最后预览版, 将在.NET Conf 2024 一起 ...

  8. redis-cli命令行工具使用

    redis 6.2.8 1.连接 ./redis-cli -h 127.0.0.1 -p 6379 -a admin@2020 -h redis主机地址 -a redis密码 -p redis端口 2 ...

  9. Win32 API 读取文件

    昨天又用Win32来读取文件的时候,又出现了字符编码的问题. 用TCHAR字符来写文件呢,用系统的记事本打开是乱码. 用CHAR字字符来写呢,在读取汉字的时候后面有一串乱码, 用CHAR[]数组读取就 ...

  10. 关于Arrays.asList返回List无法新增和删除?

    关于Arrays.asList返回的List无法新增和删除? 这个是在写项目的时候发现的,然后就分析了一下源码,得其内部原理 复现代码示例: public class ArraysAsList { p ...