back to home

dotnet / MQTTnet

MQTTnet is a high performance .NET library for MQTT based communication. It provides a MQTT client and a MQTT server (broker). The implementation is based on the documentation from http://mqtt.org/.

4,955 stars
1,146 forks
188 issues
C#CHTML

AI Architecture Analysis

This repository is indexed by RepoMind. By analyzing dotnet/MQTTnet in our AI interface, you can instantly generate complete architecture diagrams, visualize control flows, and perform automated security audits across the entire codebase.

Our Agentic Context Augmented Generation (Agentic CAG) engine loads full source files into context on-demand, avoiding the fragmentation of traditional RAG systems. Ask questions about the architecture, dependencies, or specific features to see it in action.

Source files are only loaded when you start an analysis to optimize performance.

Embed this Badge

Showcase RepoMind's analysis directly in your repository's README.

[![Analyzed by RepoMind](https://img.shields.io/badge/Analyzed%20by-RepoMind-4F46E5?style=for-the-badge)](https://repomind.in/repo/dotnet/MQTTnet)
Preview:Analyzed by RepoMind

Repository Overview (README excerpt)

Crawler view

MQTTnet MQTTnet is a high performance .NET library for MQTT based communication. It provides a MQTT client and a MQTT server ( broker) and supports the MQTT protocol up to version 5. It is compatible with mostly any supported .NET Framework version and CPU architecture. Features General • Async support • TLS support for client and server (but not UWP servers) • Extensible communication channels (e.g. In-Memory, TCP, TCP+TLS, WS) • Lightweight (only the low level implementation of MQTT, no overhead) • Performance optimized (processing ~150.000 messages / second)* • Uniform API across all supported versions of the MQTT protocol • Access to internal trace messages • Unit tested (~636 tests) • No external dependencies \* Tested on local machine (Intel i7 8700K) with MQTTnet client and server running in the same process using the TCP channel. The app for verification is part of this repository and stored in _/Tests/MQTTnet.TestApp.NetCore_. Client • Communication via TCP (+TLS) or WS (WebSocket) supported • Included core _LowLevelMqttClient_ with low level functionality • Also included _ManagedMqttClient_ which maintains the connection and subscriptions automatically. Also application messages are queued and re-scheduled for higher QoS levels automatically. • Rx support (via another project) • Compatible with Microsoft Azure IoT Hub Server (broker) • List of connected clients available • Supports connected clients with different protocol versions at the same time • Able to publish its own messages (no loopback client required) • Able to receive every message (no loopback client required) • Extensible client credential validation • Retained messages are supported including persisting via interface methods (own implementation required) • WebSockets supported (via ASP.NET Core 2.0, separate nuget) • A custom message interceptor can be added which allows transforming or extending every received application message • Validate subscriptions and deny subscribing of certain topics depending on requesting clients Getting Started MQTTnet is delivered via NuGet package manager. You can find the packages here: https://www.nuget.org/packages/MQTTnet/ Use these command in the Package Manager console to install MQTTnet manually: Samples for using MQTTnet are part of this repository. For starters these samples are recommended: • Connect with a broker • Subscribing to data • Publishing data • Host own broker Code of Conduct This project has adopted the code of conduct defined by the Contributor Covenant to clarify expected behavior in our community. For more information see the .NET Foundation Code of Conduct. .NET Foundation This project is supported by the .NET Foundation.