MQTT-C:轻量级MQTT客户端C语言实现
MQTT-C是一个轻量级的MQTT v3.1.1客户端库,采用纯C语言编写,专为嵌入式系统和PC应用设计。该项目由Liam Bindle开发,旨在提供一个跨平台的MQTT解决方案,特别适合资源受限的环境。
项目特点
轻量级设计:整个库仅包含两个源文件(mqtt.c和mqtt_pal.c),总共不到2000行代码,非常适合嵌入式系统和微控制器使用。
平台无关性:通过透明的平台抽象层(PAL)设计,使得移植到新平台变得简单。支持POSIX、Windows和各种嵌入式操作系统。
线程安全:所有API函数都是线程安全的,同时也能完美运行在单线程系统中。
ANSI C兼容:代码符合C89标准,可以使用任何C编译器进行编译。
核心功能
MQTT-C提供了完整的MQTT客户端功能:
- 连接管理(CONNECT/CONNACK)
- 消息发布(PUBLISH)
- 主题订阅(SUBSCRIBE/SUBACK)
- QoS支持(0、1、2级)
- 心跳保持(PINGREQ/PINGRESP)
- 断开连接(DISCONNECT)
快速开始
使用MQTT-C非常简单,只需要几个基本步骤:
- 初始化客户端:
struct mqtt_client client;
uint8_t sendbuf[2048], recvbuf[1024];
mqtt_init(&client, sockfd, sendbuf, sizeof(sendbuf), recvbuf, sizeof(recvbuf), publish_callback);
- 连接到代理:
mqtt_connect(&client, client_id, NULL, NULL, 0, NULL, NULL, MQTT_CONNECT_CLEAN_SESSION, 400);
- 发布消息:
mqtt_publish(&client, "topic/name", "message", strlen("message"), MQTT_PUBLISH_QOS_0);
- 订阅主题:
mqtt_subscribe(&client, "topic/name", 0);
示例应用
项目中提供了多个实用示例:
简单发布者(examples/simple_publisher.c):按回车键发布当前时间到指定主题。
简单订阅者(examples/simple_subscriber.c):订阅主题并打印接收到的消息。
重连订阅者(examples/reconnect_subscriber.c):演示自动重连功能。
加密连接示例:支持OpenSSL、mbedTLS、BearSSL等多种加密库。
构建和使用
直接编译:
gcc -o my_app my_app.c src/mqtt.c src/mqtt_pal.c -Iinclude
使用CMake:
mkdir build && cd build
cmake ..
make
使用Makefile:
make all
应用场景
物联网设备:在智能家居、工业自动化等场景中实现设备间通信。
嵌入式系统:作为微控制器与云服务交互的基础组件。
移动应用:利用低带宽消耗特性实现实时数据传输。
教学研究:学习MQTT协议和网络编程的理想起点。
许可证
MQTT-C采用MIT许可证,允许自由使用、修改和分发。
项目结构
MQTT-C/
├── include/ # 头文件
│ ├── mqtt.h # 主要API
│ └── mqtt_pal.h # 平台抽象层
├── src/ # 源文件
│ ├── mqtt.c # MQTT协议实现
│ └── mqtt_pal.c # 平台相关代码
├── examples/ # 示例代码
└── docs/ # 文档
技术优势
内存效率:优化的内存管理策略,最小化内存占用。
事件驱动:基于回调函数的异步处理设计。
错误处理:完善的错误代码体系和错误信息反馈。
协议兼容:完整支持MQTT v3.1.1协议规范。
MQTT-C是一个成熟稳定的MQTT客户端解决方案,已经在众多实际项目中得到验证。无论是初学者还是有经验的开发者,都能快速上手并构建可靠的MQTT应用。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0228
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0149
uni-appA cross-platform framework using Vue.jsJavaScript010
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
SwanLab⚡️SwanLab - an open-source, modern-design AI training tracking and visualization tool. Supports Cloud / Self-hosted use. Integrated with PyTorch / Transformers / LLaMA Factory / veRL/ Swift / Ultralytics / MMEngine / Keras etc.Python00
tiny-universe《大模型白盒子构建指南》:一个全手搓的Tiny-UniverseJupyter Notebook04
