paho mqtt client调试记录
官网:http://www.eclipse.org/paho/clients/c/
编译流程:
git clone https://github.com/eclipse/paho.mqtt.c.git cd org.eclipse.paho.mqtt.c.git make sudo make install
编译过程中报找不到clock_gettime函数的错误,在Makefile中相关位置添加-lrt就可以了。
make后sample里的测试代码也会跟着成功编译。
也可以在sample目录下单独用命令编译:gcc -I../ -L../../../paho.mqtt.c/build/output/ MQTTClient_subscribe.c -lpaho-mqtt3c -o MQTTTest -lrt
我测试了订阅部分,修改了原版demo,同时和服务器建立4个连接,每个连接又订阅了4个主题。通过对主题进行数据发送和抓包分析,都显示没问题。
修改后的代码如下:
/*******************************************************************************
* Copyright (c) 2012, 2017 IBM Corp.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* and Eclipse Distribution License v1.0 which accompany this distribution.
*
* The Eclipse Public License is available at
* http://www.eclipse.org/legal/epl-v10.html
* and the Eclipse Distribution License is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* Contributors:
* Ian Craggs - initial contribution
*******************************************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "MQTTClient.h"
//#define ADDRESS "tcp://localhost:1883"
//#define ADDRESS "192.168.0.167"
#define ADDRESS "192.168.0.117"
#define CLIENTID "ExampleClientSub"
#define TOPIC "1234/qinrenzhi"
#define TOPIC_11 "1234/qinrenzhi_11"
#define TOPIC_12 "1234/qinrenzhi_12"
#define TOPIC_13 "1234/qinrenzhi_13"
#define TOPIC_14 "1234/qinrenzhi_14"
#define PAYLOAD "Hello World!"
#define QOS 1
#define TIMEOUT 10000L
#define CLIENTID_2 "ExampleClientSub_2"
#define TOPIC_2 "1234/qinrenzhi_2"
#define TOPIC_21 "1234/qinrenzhi_21"
#define TOPIC_22 "1234/qinrenzhi_22"
#define TOPIC_23 "1234/qinrenzhi_23"
#define CLIENTID_3 "ExampleClientSub_3"
#define TOPIC_3 "1234/qinrenzhi_3"
#define TOPIC_31 "1234/qinrenzhi_31"
#define TOPIC_32 "1234/qinrenzhi_32"
#define TOPIC_33 "1234/qinrenzhi_33"
#define CLIENTID_4 "ExampleClientSub_4"
#define TOPIC_4 "1234/qinrenzhi_4"
#define TOPIC_41 "1234/qinrenzhi_41"
#define TOPIC_42 "1234/qinrenzhi_42"
#define TOPIC_43 "1234/qinrenzhi_43"
volatile MQTTClient_deliveryToken deliveredtoken_2;
void delivered_2(void *context, MQTTClient_deliveryToken dt)
{
printf("2:Message with token value %d delivery confirmed\n", dt);
deliveredtoken_2 = dt;
}
int msgarrvd_2(void *context, char *topicName, int topicLen, MQTTClient_message *message)
{
int i;
char* payloadptr;
printf("2:Message arrived\n");
printf("2: topic: %s\n", topicName);
printf("2: message: ");
payloadptr = message->payload;
for(i=0; i<message->payloadlen; i++)
{
putchar(*payloadptr++);
}
putchar('\n');
MQTTClient_freeMessage(&message);
MQTTClient_free(topicName);
return 1;
}
void connlost_2(void *context, char *cause)
{
printf("\n2:Connection lost\n");
printf(" cause: %s\n", cause);
}
volatile MQTTClient_deliveryToken deliveredtoken_3;
void delivered_3(void *context, MQTTClient_deliveryToken dt)
{
printf("3:Message with token value %d delivery confirmed\n", dt);
deliveredtoken_3 = dt;
}
int msgarrvd_3(void *context, char *topicName, int topicLen, MQTTClient_message *message)
{
int i;
char* payloadptr;
printf("3:Message arrived\n");
printf("3: topic: %s\n", topicName);
printf("3: message: ");
payloadptr = message->payload;
for(i=0; i<message->payloadlen; i++)
{
putchar(*payloadptr++);
}
putchar('\n');
MQTTClient_freeMessage(&message);
MQTTClient_free(topicName);
return 1;
}
void connlost_3(void *context, char *cause)
{
printf("\n3:Connection lost\n");
printf(" cause: %s\n", cause);
}
volatile MQTTClient_deliveryToken deliveredtoken_4;
void delivered_4(void *context, MQTTClient_deliveryToken dt)
{
printf("4:Message with token value %d delivery confirmed\n", dt);
deliveredtoken_4 = dt;
}
int msgarrvd_4(void *context, char *topicName, int topicLen, MQTTClient_message *message)
{
int i;
char* payloadptr;
printf("4:Message arrived\n");
printf("4: topic: %s\n", topicName);
printf("4: message: ");
payloadptr = message->payload;
for(i=0; i<message->payloadlen; i++)
{
putchar(*payloadptr++);
}
putchar('\n');
MQTTClient_freeMessage(&message);
MQTTClient_free(topicName);
return 1;
}
void connlost_4(void *context, char *cause)
{
printf("\n4:Connection lost\n");
printf(" cause: %s\n", cause);
}
volatile MQTTClient_deliveryToken deliveredtoken;
void delivered(void *context, MQTTClient_deliveryToken dt)
{
printf("Message with token value %d delivery confirmed\n", dt);
deliveredtoken = dt;
}
int msgarrvd(void *context, char *topicName, int topicLen, MQTTClient_message *message)
{
int i;
char* payloadptr;
printf("Message arrived\n");
printf(" topic: %s\n", topicName);
printf(" message: ");
payloadptr = message->payload;
for(i=0; i<message->payloadlen; i++)
{
putchar(*payloadptr++);
}
putchar('\n');
MQTTClient_freeMessage(&message);
MQTTClient_free(topicName);
return 1;
}
void connlost(void *context, char *cause)
{
printf("\nConnection lost\n");
printf(" cause: %s\n", cause);
}
int main(int argc, char* argv[])
{
MQTTClient client;
MQTTClient_connectOptions conn_opts = MQTTClient_connectOptions_initializer;
int rc;
int ch;
MQTTClient_create(&client, ADDRESS, CLIENTID,
MQTTCLIENT_PERSISTENCE_NONE, NULL);
conn_opts.keepAliveInterval = 200;
conn_opts.cleansession = 1;
MQTTClient_setCallbacks(client, NULL, connlost, msgarrvd, delivered);
if ((rc = MQTTClient_connect(client, &conn_opts)) != MQTTCLIENT_SUCCESS)
{
printf("Failed to connect, return code %d\n", rc);
exit(EXIT_FAILURE);
}
printf("Subscribing to topic %s\nfor client %s using QoS%d\n\n"
"Press Q<Enter> to quit\n\n", TOPIC, CLIENTID, QOS);
MQTTClient_subscribe(client, TOPIC, QOS);
MQTTClient_subscribe(client, TOPIC_11, QOS);
MQTTClient_subscribe(client, TOPIC_12, QOS);
MQTTClient_subscribe(client, TOPIC_13, QOS);
MQTTClient client_2;
MQTTClient_connectOptions conn_opts_2 = MQTTClient_connectOptions_initializer;
int rc_2;
int ch_2;
MQTTClient_create(&client_2, ADDRESS, CLIENTID_2,
MQTTCLIENT_PERSISTENCE_NONE, NULL);
conn_opts_2.keepAliveInterval = 200;
conn_opts_2.cleansession = 1;
MQTTClient_setCallbacks(client_2, NULL, connlost_2, msgarrvd_2, delivered_2);
if ((rc_2 = MQTTClient_connect(client_2, &conn_opts_2)) != MQTTCLIENT_SUCCESS)
{
printf("2:Failed to connect, return code %d\n", rc);
exit(EXIT_FAILURE);
}
printf("2:Subscribing to topic %s\nfor client %s using QoS%d\n\n"
"Press Q<Enter> to quit\n\n", TOPIC_2, CLIENTID_2, QOS);
MQTTClient_subscribe(client_2, TOPIC_2, QOS);
MQTTClient_subscribe(client_2, TOPIC_21, QOS);
MQTTClient_subscribe(client_2, TOPIC_22, QOS);
MQTTClient_subscribe(client_2, TOPIC_23, QOS);
MQTTClient client_3;
MQTTClient_connectOptions conn_opts_3 = MQTTClient_connectOptions_initializer;
int rc_3;
int ch_3;
MQTTClient_create(&client_3, ADDRESS, CLIENTID_3,
MQTTCLIENT_PERSISTENCE_NONE, NULL);
conn_opts_3.keepAliveInterval = 200;
conn_opts_3.cleansession = 1;
MQTTClient_setCallbacks(client_3, NULL, connlost_3, msgarrvd_3, delivered_3);
if ((rc_3 = MQTTClient_connect(client_3, &conn_opts_3)) != MQTTCLIENT_SUCCESS)
{
printf("3:Failed to connect, return code %d\n", rc);
exit(EXIT_FAILURE);
}
printf("3:Subscribing to topic %s\nfor client %s using QoS%d\n\n"
"Press Q<Enter> to quit\n\n", TOPIC_3, CLIENTID_3, QOS);
MQTTClient_subscribe(client_3, TOPIC_3, QOS);
MQTTClient_subscribe(client_3, TOPIC_31, QOS);
MQTTClient_subscribe(client_3, TOPIC_32, QOS);
MQTTClient_subscribe(client_3, TOPIC_33, QOS);
MQTTClient client_4;
MQTTClient_connectOptions conn_opts_4 = MQTTClient_connectOptions_initializer;
int rc_4;
int ch_4;
MQTTClient_create(&client_4, ADDRESS, CLIENTID_4,
MQTTCLIENT_PERSISTENCE_NONE, NULL);
conn_opts_4.keepAliveInterval = 200;
conn_opts_4.cleansession = 1;
MQTTClient_setCallbacks(client_4, NULL, connlost_4, msgarrvd_4, delivered_4);
if ((rc_4 = MQTTClient_connect(client_4, &conn_opts_4)) != MQTTCLIENT_SUCCESS)
{
printf("4:Failed to connect, return code %d\n", rc);
exit(EXIT_FAILURE);
}
printf("4:Subscribing to topic %s\nfor client %s using QoS%d\n\n"
"Press Q<Enter> to quit\n\n", TOPIC_4, CLIENTID_4, QOS);
MQTTClient_subscribe(client_4, TOPIC_4, QOS);
MQTTClient_subscribe(client_4, TOPIC_41, QOS);
MQTTClient_subscribe(client_4, TOPIC_42, QOS);
MQTTClient_subscribe(client_4, TOPIC_43, QOS);
do
{
ch = getchar();
} while(ch!='Q' && ch != 'q');
MQTTClient_unsubscribe(client, TOPIC);
MQTTClient_unsubscribe(client, TOPIC_11);
MQTTClient_unsubscribe(client, TOPIC_12);
MQTTClient_unsubscribe(client, TOPIC_13);
MQTTClient_disconnect(client, 10000);
MQTTClient_destroy(&client);
MQTTClient_unsubscribe(client_2, TOPIC);
MQTTClient_unsubscribe(client_2, TOPIC_21);
MQTTClient_unsubscribe(client_2, TOPIC_22);
MQTTClient_unsubscribe(client_2, TOPIC_23);
MQTTClient_disconnect(client_2, 10000);
MQTTClient_destroy(&client_2);
MQTTClient_unsubscribe(client_3, TOPIC);
MQTTClient_unsubscribe(client_3, TOPIC_31);
MQTTClient_unsubscribe(client_3, TOPIC_32);
MQTTClient_unsubscribe(client_3, TOPIC_33);
MQTTClient_disconnect(client_3, 10000);
MQTTClient_destroy(&client_3);
MQTTClient_unsubscribe(client_4, TOPIC);
MQTTClient_unsubscribe(client_4, TOPIC_41);
MQTTClient_unsubscribe(client_4, TOPIC_42);
MQTTClient_unsubscribe(client_4, TOPIC_43);
MQTTClient_disconnect(client_4, 10000);
MQTTClient_destroy(&client_4);
return rc;
}
paho mqtt client调试记录相关推荐
- Eclipse Paho MQTT Python Client 使用手册
Eclipse Paho MQTT Python Client 使用手册 原文地址:https://www.cooooder.com/archives/20210303 目录 介绍 环境 准备 快速开 ...
- Python模拟智能开关设备MQTT接入阿里云物联网平台 - PyCharm paho.mqtt
概要 Python 使用 paho.mqtt 库,利用阿里云物联网平台的设备证书:productKey.deviceName.deviceSecret,自动合成 userName.passWord.以 ...
- 使用Python将MQTT传感器数据记录到SQL数据库
使用Python将MQTT传感器数据记录到SQL数据库 在这个项目中,我们将创建一个简单的数据记录器,将数据记录到sqlite数据库. 该项目包括两个模块. sql logger类模块sql_logg ...
- 小程序paho.mqtt连接微消息队列 MQTT 版
物联网项目现在越来越多,MQTT的使用场景也越来越广泛,同时遇到的技术问题也是越来越复杂. 最近在做一个小程序连接阿里云的微消息队列MQTT版,说实话,通过这次debug,发现阿里的技术文档很多方面不 ...
- Paho MQTT Python客户端常用API、安装与使用
MQTT(Message Queuing Telemetry Transport)是一种轻量级的即时通信协议,相关介绍可见:MQTT简介. Paho 是Eclipse的开源 MQTT 客户端项目,提供 ...
- paho.mqtt.c打印日志
方法一.调用api设置 在创建client前,添加如下两句: MQTTAsync_setTraceCallback(trace_callback); MQTTAsync_setTraceLevel(M ...
- cmake:VS2015和GCC编译paho.mqtt C/C++ client
paho.mqtt.c是eclipse开发的C语言跨平台mqtt client 开源库,paho.mqtt.cpp是对应的C++ Client,paho.mqtt支持CMAKE编译,本文以脚本形式提供 ...
- paho架构_GitHub - yanzhangfeng/paho-mqtt: Eclipse Paho MQTT C/C++ client for Embedded platforms
paho-mqtt 1.介绍 Paho MQTT 是 Eclipse 实现的基于 MQTT 协议的客户端,本软件包是在 Eclipse paho-mqtt 源码包的基础上设计的一套 MQTT 客户端程 ...
- Paho Java Client 连接阿里云物联网平台
Paho Java Client 连接阿里云物联网平台 进入阿里云物联网平台->点击产品->新建 点击设备->添加设备 查看设备证书,复制记录,后面使用 阿里云TCP通信 一机一密. ...
最新文章
- 修改Activity响应音量控制键修改的音频流
- 阿里云centos配置nginx和nodejs
- 面经:什么是Transformer位置编码?
- 通用双向链表的设计(参考Linux系统中的实现)
- Ibatis.Net 学习手记一 简单的Demo
- css 浮动和清除浮动
- oracle 运营维护_Oracle数据库日常运维常用脚本
- alwayson高可用组_AlwaysOn可用性组–简化工作的好奇心–第3部分
- java jexl_利用Jexl实现数据库的计算公式在Java中执行
- 根据百度的语音识别例子,展示C如何调用C++库
- 一级计算机考试中的DBF,2017年计算机等考一级WPS2000辅导:使用DBF格式内容的方法...
- Excel学习笔记 - 单元格的引用
- EL表达式与JSTL标签库
- PDF怎么裁剪页面,PDF裁剪页面的操作步骤
- 天津2019全国计算机二级,2019年上半年全国计算机等级考试报名啦
- 短时傅里叶变换原理及其MATLAB实现(Short Time Fourier Transform,STFT)
- Python基础——数据类型—元组
- 领导者如何激发员工成就感
- THORChain被盗:黑客资金溯源报告
- 用EDA处理蛋白质数据小记
热门文章
- 完整的一次 HTTP 请求响应过程(一)
- 海量数据处理:两个大文件中的相同记录
- 15.赋值运算符为什么返回类的引用?不是引用怎么办?
- java随机数转换_Java获取随机数的3种方法(转)
- 2026年,数据中心电力市场将达到150亿美元
- 模块化数据中心有什么优势?
- 菲律宾达沃照明和电力公司的数据中心发生火灾
- linux如何查看硬件驱动,linux查看硬件信息及驱动设备相关整理
- 成功解决ModuleNotFoundError: No module named ‘torch._C‘
- CV之FR:计算机视觉之人脸识别(Face Recognition)方向的简介、代码实现、案例应用之详细攻略