记OpenDDS订阅内置主题的一些坑

由于某个需求,现在需要订阅OpenDDS的内置主题,首先我们通过官方文档来看下OpenDDS有哪些内置主题:

一共四个,分别对应参与者、主题、生产者、订阅者,这次我们要订阅的是Topic的信息,但是这里没有说明该怎么订阅,也没说明这四个主题的消息格式是怎样的,不要急,往下翻一下第六章就能看到:

我们可以看到,DCPSTopic这个主题的消息类型为TopicBuiltinTopicData,本章最后一小节给出的是DCPSParticipant主题的C++示例代码,那么我们仿照着写出DCPSTopic的Java代码:

        DomainParticipantFactory dpf = TheParticipantFactory.WithArgs(new StringSeqHolder(args));
        if (dpf == null) {
            return;
        }
        DomainParticipant dp = dpf.create_participant(4, PARTICIPANT_QOS_DEFAULT.get(), null, DEFAULT_STATUS_MASK.value);
        if (dp == null) {
            return;
        }
        // 订阅内置主题DCPSTopic
        Subscriber subscriber = dp.get_builtin_subscriber();
        DataReader dr = subscriber.lookup_datareader("DCPSTopic");
        TopicBuiltinTopicDataDataRea
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在使用OpenDDS配置分布式发布订阅模式时,需要进行以下步骤: 1. 定义IDL文件:首先需要定义数据类型以及接口服务,使用OpenDDS的接口描述语言(IDL)进行定义。IDL文件描述了发布者和订阅者之间需要交换的数据类型和消息格式。 2. 生成实现代码:使用OpenDDS提供的IDL编译器将IDL文件编译成对应的实现代码,生成服务端和客户端的代码。 3. 配置发布者和订阅者:在发布者端,配置发布者的QoS(Quality of Service,服务质量),可以设置消息可靠性、延迟要求、带宽等等。在订阅者端,配置订阅者的QoS,可以设置接收方式(持久性或非持久性)、接收缓冲区大小等。 4. 配置域和主题:在OpenDDS中,域和主题是将发布者和订阅者组织起来的重要概念。通过配置不同的域和主题,可以实现不同细粒度的消息传递。 5. 构建和运行应用程序:将生成的实现代码与应用程序源代码进行编译和链接,生成可执行文件。通过启动发布者和订阅者应用程序,可以实现消息的发布和订阅。 6. 执行分布式配置:在分布式环境中,需要在发布者和订阅者之间进行网络配置,确保消息的正确传递。可以使用OpenDDS提供的配置工具来进行配置,如DCPSInfoRepo用于管理域和主题的注册信息。 通过以上步骤,就可以成功配置分布式发布订阅模式。在此模式下,发布者可以将消息发布到特定的主题中,而订阅者则可以从相应的主题中接收到消息。OpenDDS提供了强大的工具和机制,用于实现高效可靠的分布式消息传递。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值