利用MQTT一次订阅多个主题

                     利用MQTT一次订阅多个主题

在做智能家居相关的应用时候,需要利用订阅所有设备的主题。这个时候我们需要利用mqtt的通配符的功能,一个订阅可能包含特殊字符,允许你一次定义多个主题。主题层次分隔符被用来在主题中引入层次。多层的通配符和单层通配符可以被使用,但他们不能被使用来做发布者的消息。

 

 

1.主题层级分隔符/

/ 被用来分割主题树的每一层,并给主题空间提供分等级的结构。当两个通配符在一个主题中出现的时候,主题层次分隔符的使用是很重要的。

 

2.多层通配符#

 

#是一个匹配主题中任意层次数的通配符。比如说,如果你订阅了finance/stock/ibm/#,你就可以接收到以下这些主题的消息。

finance/stock/ibm
finance/stock/ibm/closingprice
finance/stock/ibm/currentprice

多层通配符有可以表示大于等于0的层次。因此,finance/#也可以匹配到单独的finance,在这种情况下#代表0层。在这种语境下主题层次分隔符/就没有意义了。因为没有可以分的层次。

多层通配符只可以确定当前层或者下一层。因此,#finance/#都是有效的,但是finance#不是有效的。多层通配符一定要是主题树的最后一个字符。比如说,finance/#是有效的,但是finance/#/closingprice是无效的。

 

3.单层通配符+

 

+只匹配主题的一层。比如说,finance/stock/+匹配finance/stock/ibmfinance/stock/xyz,但是不匹配finance/stock/ibm/closingprice。另外,因为单层通配符只匹配1层,finance/+不匹配finance

单层通配符可以被用于主题树的任意层级,连带多层通配符。它必须被用在主题层级分隔符/的右边,除非它是指定自己。因此,+finance/+都是有效的,但是finance+无效。单层通配符可以用在主题树的末端,也可以用在中间。比如说,finance/+finance/+/ibm都是有效的。

 

4.主题语法和用法

当你建立一个应用,设计主题树的时候应该考虑以下的主题名字的语法和语义:

 

  • 主题至少有一个字符长。
  • 主题名字是大小写敏感的。比如说,ACCOUNTS和Accounts是两个不同的主题。
  • 主题名字可以包含空格。比如,Accounts payable是一个有效的主题。
  • /开头会产生一个不同的主题。比如说,/finnacefinance不同。/finance匹配"+/+"/+,但不匹配+
  • 不要在任何主题中包含null(Unicode \x0000)字符。

以下的原则应用于主题树的建造和内容

  • 在主题树中,长度被限制于64k内但是在这以内没有限制层级的数目 。
  • 可以有任意数目的根节点;也就是说,可以有任意数目的主题树。

 

  • 10
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 13
    评论
### 回答1: 在Linux平台上使用C语言进行MQTT开发,可以使用paho.mqtt.c库来定义多个topic实例程序。paho.mqtt.c是一个高效且易于使用的MQTT客户端库,提供了一组API函数来实现与MQTT代理的通信。 首先,我们需要在项目中引入paho.mqtt.c库的头文件,并在代码中初始化MQTT客户端。然后,我们可以使用`MQTTClient`结构体来定义多个MQTT客户端实例,并设置每个实例的配置参数,包括服务器地址、端口号、客户端ID等。例如,我们可以创建如下两个MQTT客户端实例: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <MQTTClient.h> #define ADDRESS "tcp://localhost:1883" // MQTT代理地址 #define CLIENTID1 "client1" // 客户端ID1 #define CLIENTID2 "client2" // 客户端ID2 #define TOPIC1 "topic1" // 主题1 #define TOPIC2 "topic2" // 主题2 int main() { MQTTClient client1, client2; MQTTClient_connectOptions conn_opts1 = MQTTClient_connectOptions_initializer; MQTTClient_connectOptions conn_opts2 = MQTTClient_connectOptions_initializer; int rc; // 初始化MQTT客户端 MQTTClient_create(&client1, ADDRESS, CLIENTID1, MQTTCLIENT_PERSISTENCE_NONE, NULL); MQTTClient_create(&client2, ADDRESS, CLIENTID2, MQTTCLIENT_PERSISTENCE_NONE, NULL); // 设置MQTT客户端连接参数 conn_opts1.keepAliveInterval = 20; conn_opts2.keepAliveInterval = 20; // 连接MQTT代理 MQTTClient_connect(client1, &conn_opts1); MQTTClient_connect(client2, &conn_opts2); // 订阅主题 MQTTClient_subscribe(client1, TOPIC1, 1); MQTTClient_subscribe(client2, TOPIC2, 1); // 在这里可以实现对连接的消息进行处理 // ... // 断开MQTT代理的连接 MQTTClient_disconnect(client1, 0); MQTTClient_disconnect(client2, 0); // 销毁MQTT客户端 MQTTClient_destroy(&client1); MQTTClient_destroy(&client2); return 0; } ``` 在上述示例代码中,我们创建了两个MQTTClient结构体,分别代表两个不同的MQTT客户端实例。通过设置每个实例的客户端ID、服务器地址以及其他连接参数,可以实现与不同主题进行通信。然后,我们可以使用MQTTClient_subscribe函数来订阅相应的主题,并在所需的位置对收到的消息进行处理。 以上就是使用paho.mqtt.c库来开发定义多个topic实例程序的简要示例。通过该示例,我们可以利用C语言在Linux平台上轻松实现多个MQTT客户端实例,并订阅不同的主题进行通信。 ### 回答2: 利用Paho MQTT C库进行MQTT开发,可以定义多个Topic实例程序。首先,我们需要下载和安装Paho MQTT C库。在Linux中,可以通过包管理器或者从Paho官方网站下载源代码来进行安装。 安装完成后,我们可以开始编写程序。首先,我们需要在程序中包含Paho MQTT C库的头文件。例如,可以使用以下指令包含头文件: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include "MQTTClient.h" ``` 接下来,我们需要定义多个Topic实例。可以使用MQTTClient_create函数来创建不同的Topic实例。例如,我们可以创建两个不同的Topic实例,分别订阅和发布不同的主题: ```c MQTTClient client1; MQTTClient client2; ``` 在定义Topic实例后,我们需要配置每个实例的连接选项,例如MQTT服务器的地址和端口号等。可以使用MQTTClient_connectOptions结构体来设置连接选项。例如,可以设置client1的连接选项如下: ```c MQTTClient_connectOptions conn_opts1 = MQTTClient_connectOptions_initializer; conn_opts1.username = "username"; conn_opts1.password = "password"; conn_opts1.keepAliveInterval = 20; // 其他连接参数 ``` 然后,我们需要连接到MQTT服务器。可以使用MQTTClient_connect函数来连接。例如,可以分别连接client1和client2: ```c MQTTClient_create(&client1, "tcp://localhost:1883", "Client1"); MQTTClient_create(&client2, "tcp://localhost:1883", "Client2"); int rc1 = MQTTClient_connect(client1, &conn_opts1); int rc2 = MQTTClient_connect(client2, &conn_opts2); ``` 连接成功后,我们可以订阅和发布消息。可以使用MQTTClient_subscribe函数来订阅主题,使用MQTTClient_publish函数来发布消息。例如,我们可以分别订阅和发布不同的主题: ```c MQTTClient_subscribe(client1, "topic1", QOS); MQTTClient_subscribe(client2, "topic2", QOS); MQTTClient_publish(client1, "topic1", strlen("message1"), "message1", QOS, 0, NULL); MQTTClient_publish(client2, "topic2", strlen("message2"), "message2", QOS, 0, NULL); ``` 最后,我们需要断开连接并清理资源。可以使用MQTTClient_disconnect函数来断开连接,使用MQTTClient_destroy函数来销毁Topic实例。例如,可以分别断开连接并销毁client1和client2: ```c MQTTClient_disconnect(client1, 1000); MQTTClient_disconnect(client2, 1000); MQTTClient_destroy(&client1); MQTTClient_destroy(&client2); ``` 以上就是利用Paho MQTT C库进行MQTT开发,定义多个Topic实例的简单示例程序。可以根据实际需求进行修改和扩展。
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值