python与c++程序通过mqtt通信

23 篇文章 0 订阅
16 篇文章 0 订阅

mqtt安装与基本测试

#安装mosquitto mqtt
#引入仓库
sudo apt-add-repository ppa:mosquitto-dev/mosquitto-ppa
#更新源
sudo apt-get update
#安装mosquitto
sudo apt install mosquitto
#安装客户端
sudo apt-get install mosquitto-clients
######测试
#一个终端开启sub mqtt
mosquitto_sub -h localhost -t "test_local" -v
#另一个终端发布信息,看能否收到
mosquitto_pub -h localhost -t "test_local" -m "HELLO MQTT"

若sub的中端收到,那么mqtt安装成功。

python部分

#api参考网站
https://pypi.org/project/paho-mqtt/#usage-and-api
#安装pip
sudo apt install python-pip
#安装python 的mqtt包
pip install paho-mqtt
publish.single("MQTT Examples", 2); 第一个参数为mqtt的topic第二个是内容。
import paho.mqtt.publish as publish

publish.single("MQTT Examples", 2)

c++部分

#paho.mqtt.c 库
https://github.com/eclipse/paho.mqtt.c

#下载oaho c库
git clone https://github.com/eclipse/paho.mqtt.c.git
#编译安装
make
sudo make install

#编译sub程序
g++ MQTTClient_subscribe.c -o sub -lpaho-mqtt3c

/*******************************************************************************
 * Copyright (c) 2012, 2020 IBM Corp.
 *
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v2.0
 * and Eclipse Distribution License v1.0 which accompany this distribution. 
 *
 * The Eclipse Public License is available at 
 *   https://www.eclipse.org/legal/epl-2.0/
 * 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     "localhost"
#define CLIENTID    "ExampleClientSub"
#define TOPIC       "MQTT Examples"
#define PAYLOAD     "Hello World!"
#define QOS         1
#define TIMEOUT     10000L

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)
{
    printf("Message arrived\n");
    printf("     topic: %s\n", topicName);
    printf("   message: %.*s\n", message->payloadlen, (char*)message->payload);
    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;

    if ((rc = MQTTClient_create(&client, ADDRESS, CLIENTID,
        MQTTCLIENT_PERSISTENCE_NONE, NULL)) != MQTTCLIENT_SUCCESS)
    {
        printf("Failed to create client, return code %d\n", rc);
        rc = EXIT_FAILURE;
        goto exit;
    }

    if ((rc = MQTTClient_setCallbacks(client, NULL, connlost, msgarrvd, delivered)) != MQTTCLIENT_SUCCESS)
    {
        printf("Failed to set callbacks, return code %d\n", rc);
        rc = EXIT_FAILURE;
        goto destroy_exit;
    }

    conn_opts.keepAliveInterval = 20;
    conn_opts.cleansession = 1;
    if ((rc = MQTTClient_connect(client, &conn_opts)) != MQTTCLIENT_SUCCESS)
    {
        printf("Failed to connect, return code %d\n", rc);
        rc = EXIT_FAILURE;
        goto destroy_exit;
    }

    printf("Subscribing to topic %s\nfor client %s using QoS%d\n\n"
           "Press Q<Enter> to quit\n\n", TOPIC, CLIENTID, QOS);
    if ((rc = MQTTClient_subscribe(client, TOPIC, QOS)) != MQTTCLIENT_SUCCESS)
    {
    	printf("Failed to subscribe, return code %d\n", rc);
    	rc = EXIT_FAILURE;
    }
    else
    {
    	int ch;
    	do
    	{
        	ch = getchar();
    	} while (ch!='Q' && ch != 'q');

        if ((rc = MQTTClient_unsubscribe(client, TOPIC)) != MQTTCLIENT_SUCCESS)
        {
        	printf("Failed to unsubscribe, return code %d\n", rc);
        	rc = EXIT_FAILURE;
        }
    }

    if ((rc = MQTTClient_disconnect(client, 10000)) != MQTTCLIENT_SUCCESS)
    {
    	printf("Failed to disconnect, return code %d\n", rc);
    	rc = EXIT_FAILURE;
    }
destroy_exit:
    MQTTClient_destroy(&client);
exit:
    return rc;
}

通信

先执行c++的程序,然后执行python ,能够拿到数据。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 你好,以下是一个 ROS 和 MQTT 通信的示例: 首先,需要安装 ROS 和 MQTT 的相关库和依赖。然后,可以使用 ROS 的 roscpp 库和 MQTT 的 Eclipse Paho C++ 客户端库来实现通信。 在 ROS 中,可以使用 roscpp 的 Publisher 和 Subscriber 类来发布和订阅 ROS 消息。在 MQTT 中,可以使用 Eclipse Paho C++ 客户端库的 MQTTClient 类来连接 MQTT 代理服务器,并发布和订阅 MQTT 消息。 下面是一个简单的 ROS 和 MQTT 通信示例: 1. 创建 ROS 节点和 MQTT 客户端 ros::init(argc, argv, "ros_mqtt_node"); ros::NodeHandle nh; MQTTClient client("tcp://localhost:1883", "ros_mqtt_client"); 2. 创建 ROS 发布者和订阅者 ros::Publisher pub = nh.advertise<std_msgs::String>("ros_mqtt_topic", 100); ros::Subscriber sub = nh.subscribe("ros_mqtt_topic", 100, &callback); 3. 创建 MQTT 订阅者和发布者 client.subscribe("mqtt_ros_topic", ); client.publish("mqtt_ros_topic", "Hello, MQTT!"); 4. 实现 ROS 回调函数和 MQTT 回调函数 void callback(const std_msgs::String::ConstPtr& msg) { ROS_INFO("Received ROS message: %s", msg->data.c_str()); client.publish("mqtt_ros_topic", msg->data.c_str()); } void mqtt_callback(void* context, char* topicName, int topicLen, MQTTClient_message* message) { ROS_INFO("Received MQTT message: %s", message->payload); std_msgs::String msg; msg.data = std::string(message->payload); pub.publish(msg); } 5. 运行 ROS 节点和 MQTT 客户端 ros::spin(); MQTTClient_setCallbacks(client, NULL, NULL, mqtt_callback, NULL); MQTTClient_connect(client, &conn_opts); MQTTClient_subscribe(client, "mqtt_ros_topic", ); 注意,这只是一个简单的示例,实际应用中需要根据具体需求进行修改和优化。 ### 回答2: ROS (Robot Operating System) 是一个灵活的开源框架,用于构建机器人软件应用程序MQTT (Message Queuing Telemetry Transport) 是一个轻量级的通信协议,用于物联网设备之间的通信。在ROS中使用MQTT进行通信可以实现ROS和其他设备的互联互通。 ROS中的mqtt_bridge软件包提供了ROS和MQTT之间的桥接功能。通过安装该软件包并配置相应参数,可以使ROS节点与MQTT代理之间进行通信。下面以订阅和发布两种常见的通信方式为例进行说明。 首先,在ROS中订阅MQTT消息,可以使用rospy.Subscriber来订阅特定话题。例如,可以通过如下方式在ROS中订阅名为“mqtt_topic”的MQTT话题: ``` rospy.Subscriber("mqtt_topic", MsgType, callback) ``` 其中,MsgType表示消息类型,callback是回调函数,用于处理接收到的消息。 接下来,在ROS中发布MQTT消息,可以使用rospy.Publisher来发布特定话题。例如,可以通过如下方式在ROS中发布名为“mqtt_topic”的MQTT话题: ``` rospy.Publisher("mqtt_topic", MsgType).publish(message) ``` 其中,MsgType表示消息类型,message为要发布的消息内容。 通过配置mqtt_bridge的参数,可以将ROS节点与MQTT代理连接起来。在mqtt_bridge的配置文件中,可以设置ROS和MQTT之间的话题映射关系,例如将“ros_topic”映射到“mqtt_topic”。 ``` ros_topic: mqtt_topic ``` 这样,当ROS节点发布“ros_topic”话题时,mqtt_bridge会将该消息转发到MQTT代理,同时,当MQTT代理发布“mqtt_topic”话题时,mqtt_bridge会将该消息转发给ROS节点。 综上所述,通过使用mqtt_bridge软件包,可以实现ROS和MQTT之间的通信。只需订阅和发布相应的话题即可实现消息传递。这样,ROS节点可以与其他设备实现无缝连接,实现更灵活的机器人应用程序开发。 ### 回答3: ROS (Robot Operating System) 是一个用于开发机器人软件的开源框架,MQTT (Message Queuing Telemetry Transport) 是一种轻量级的通信协议。在 ROS 中使用 MQTT 进行通信可以实现机器人与其他设备之间的消息传递和数据交换。 为了在 ROS 中使用 MQTT 进行通信,首先需要安装 ROS MQTT 包。可以使用命令行运行以下命令来安装: ``` $ sudo apt-get install ros-<distro>-mqtt ``` 在 ROS 中使用 MQTT,通常需要创建一个 ROS 节点来订阅和发布 MQTT 消息。下面是一个使用 ROS MQTT 包的示例代码: ```python import rospy from std_msgs.msg import String from mqtt_ros_bridge.msg import MqttMsg def mqtt_callback(msg): # 当从 MQTT 接收到消息时的回调函数 rospy.loginfo("Received MQTT message: %s", msg.payload.data) def ros_callback(msg): # 当从 ROS 主题接收到消息时的回调函数 # 发布 MQTT 消息 mqtt_msg = MqttMsg() mqtt_msg.topic = "mqtt_topic" mqtt_msg.payload = msg.data mqtt_msg.qos = 0 mqtt_pub.publish(mqtt_msg) rospy.init_node('mqtt_example') # 创建 MQTT 订阅节点 mqtt_sub = rospy.Subscriber('mqtt_topic', MqttMsg, mqtt_callback) # 创建 MQTT 发布节点 mqtt_pub = rospy.Publisher('mqtt_topic', MqttMsg, queue_size=10) # 创建 ROS 主题订阅节点 ros_sub = rospy.Subscriber('ros_topic', String, ros_callback) rospy.spin() ``` 在这个示例中,我们创建了一个 ROS 节点,并使用 ROS MQTT 包提供的功能创建了一个 MQTT 订阅节点和一个 MQTT 发布节点。通过在回调函数中实现 MQTT 消息的处理,我们可以在 ROS 和 MQTT 之间进行双向通信。 通过运行这个示例代码,ROS 节点将能够接收来自 MQTT 消息的数据,并将其打印出来。同时,它还可以订阅 ROS 主题,并将接收到的消息发布到 MQTT。 这是一个简单的 ROS MQTT 通信示例,可以根据实际需求进行扩展和定制。通过使用 ROS MQTT 包,可以方便地在 ROS 系统中集成 MQTT,实现机器人与其他设备之间的无缝通信

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值