使用 boost::asio 在同一主机上多播消息

Posted

技术标签:

【中文标题】使用 boost::asio 在同一主机上多播消息【英文标题】:Multicast message on same host using boost::asio 【发布时间】:2011-11-26 11:17:31 【问题描述】:

我正在实现发送方/接收方应用程序以在同一主机上进行多播通信。

在我的构造函数中,我有以下代码来设置套接字。

boost::asio::ip::udp::endpoint listenEndpoint(listenAddr, mcastPort);
m_socket.open(listenEndpoint.protocol());
m_socket.set_option(boost::asio::ip::udp::socket::reuse_address(true));
m_socket.set_option(boost::asio::ip::multicast::enable_loopback(true));
m_socket.set_option(boost::asio::ip::multicast::hops(1));
m_socket.bind(listenEndpoint);

// Join the multicast group
m_socket.set_option(boost::asio::ip::multicast::join_group(mcastAddr));

m_socket.async_receive_from(boost::asio::buffer(m_data, MAX_PTP_MSG_LENGTH),
        m_senderEndpoint, boost::bind(&PtpIpc::HandleReceiveFrom, this, 
        boost::asio::placeholders::error,
        boost::asio::placeholders::bytes_transferred));

其中 listenAddr 为 0.0.0.0。

我的发送方法代码如下:

m_socket.async_send_to(boost::asio::buffer(data, size), m_remoteEndpoint,
    boost::bind(&PtpIpc::HandleSendTo, this,
    boost::asio::placeholders::error,
    boost::asio::placeholders::bytes_transferred));

其中 m_remoteEndpoint 是多播地址 224.0.1.129 和多播端口 320。

应用程序 A 似乎没有从应用程序 B 接收多播消息,反之亦然,当两者都在同一主机上时。但是,如果我将应用程序 B 移动到同一子网中的另一台机器......然后应用程序 A 听到多播消息并回复给应用程序 B,它也可以接收来自应用程序 A 的回复消息。我启用了环回并设置了套接字重用地址选项。我错过了什么?

【问题讨论】:

这种行为很常见;我还在完全不同的操作系统(例如 Tru64 Unix)上看到过它。您使用的是什么操作系统? @Ben 我正在使用 Linux 内核 2.6.29 在 Timesys 下进行开发。谢谢! 应用程序 A 和 B 是否都加入了多播组,并且都向/从该组发送和接收?此外,您是否有单独的套接字用于从多播组接收与发送到组? @Dave:是的,应用程序 A 和 B 都加入了多播组,并且向/从同一个组发送/接收。正如我最初提到的,它们在不同的机器上都可以正常工作,但在同一台主机上就不行了。我使用同一个套接字向组发送和接收,并尝试使用单独的套接字......但在同一台机器上两种方法都不起作用。 好吧,我建议尝试使用单独的发送/接收套接字,并将接收套接字绑定到多播地址。我平时就是这样,没有遇到你描述的问题。 【参考方案1】:

删除环回选项后会发生什么。我有一个类似的问题,并删除它修复它。

【讨论】:

以上是关于使用 boost::asio 在同一主机上多播消息的主要内容,如果未能解决你的问题,请参考以下文章

boost::asio 完全断开连接

绑定多播 (UDP) 套接字是啥意思?

使用 Boost.ASIO [WebSocket] 完整阅读消息

boost::asio 中的 NAT 打孔

创建使用 Boost ASIO 且不公开它的静态库

使用 boost::asio 丢弃数据