首页 > 解决方案 > UDP广播丢失的数据包比接收的多?

问题描述

场景:
我有一个简单的程序,可以通过p2p-wlan0-0Linux 上的 bcast 接口广播一条小消息。以下是程序。

代码:

#include <boost/asio.hpp>
#include <boost/system/error_code.hpp>

#include <iostream>
#include <memory>
#include <string>
#include <thread>

boost::asio::io_service ioService;
boost::asio::ip::udp::socket udpSocket = boost::asio::ip::udp::socket(ioService);
boost::asio::ip::udp::endpoint  endPoint;

void Prepare() {
    const int port = 36512; // Some port
    const std::string& broadcastIPAddress = "192.168.1.1";

    udpSocket.open(boost::asio::ip::udp::v4());
    udpSocket.set_option(boost::asio::socket_base::reuse_address(true));
    udpSocket.set_option(boost::asio::socket_base::broadcast(true));

    boost::asio::ip::address_v4 address =  boost::asio::ip::address_v4::from_string(broadcastIPAddress);
    boost::asio::ip::address_v4 broadcastAddressV4 = boost::asio::ip::address_v4::broadcast(address,
                                                    boost::asio::ip::address_v4::from_string("255.255.255.0")) ;
    endPoint = boost::asio::ip::udp::endpoint(broadcastAddressV4, port);
    boost::asio::ip::address interfaceIPAddress(boost::asio::ip::address_v4::from_string(broadcastIPAddress));
    boost::system::error_code ec;
    udpSocket.set_option(boost::asio::ip::multicast::outbound_interface(interfaceIPAddress.to_v4()), ec);
    if (ec) {
        throw std::runtime_error(ec.message());
    }
}

void Broadcast(const std::string& messageToBroadcast) {
    boost::system::error_code ec;
    udpSocket.send_to(boost::asio::buffer(messageToBroadcast.c_str(), messageToBroadcast.length()), endPoint, 0, ec);
    if (ec) {
        throw std::runtime_error(ec.message());
    }
    std::cout << "Broadcasted udp message " << messageToBroadcast << std::endl;
}

int main() {
    std::cout << "Program starts" << std::endl;
    std::atomic<bool> stopped{false};
    std::thread t([&stopped](){
        std::cout << "Broadcasting thread starting up" << std::endl;
        Prepare();
        do {
            Broadcast("hello");
            std::this_thread::sleep_for(std::chrono::seconds(1));
        } while(!stopped.load());
    });

    std::this_thread::sleep_for(std::chrono::minutes(1));
    stopped.store(true);
    t.join();

    std::cout << "Program ends" << std::endl;
}

Receiver是一个盲接收数据的接收循环。整个事情都有效。我能够发送和接收数据包。

问题:
但是,我在广播接口上丢失了很多数据包。它就像收到了十分之一的数据包。我很惊讶,因为它是一个 p2p 连接。我需要 10 次广播才能在接收方收到一个。真的很奇怪!
这是它应该如何工作的性质吗?UDP广播这么不可靠吗?还是我在设置 UDP 套接字的方式上做错了?

标签: udpboost-asioembedded-linuxbroadcast

解决方案


推荐阅读