Этот сервер boost udp не работает должным образом.
Он идентичен блокирующему эхо-серверу UDP, ЗА ИСКЛЮЧЕНИЕМ незначительных изменений. Я использую другой сокет для возврата ответа, то есть sock2. Теперь этот код отлично работает, если клиент находится на той же машине, что и сервер. Но в тот момент, когда я запускаю это на другой машине, ответ не получен. Однако, если я изменю отправляющий сокет на sock, а не на sock2, он будет работать на разных машинах.
Любая идея, почему это было бы? Wireshark вообще не показывает никаких ошибок. Клиент использует случайный исходный порт, но затем вызывает recv_from для того же случайного порта. Сервер отправляет ответ обратно на тот же номер порта, который затем прослушивает клиент.
#include <cstdlib>
#include <iostream>
#include <boost/asio.hpp>
using boost::asio::ip::udp;
enum { max_length = 1024 };
void server(boost::asio::io_service& io_service, short port)
{
udp::socket sock(io_service, udp::endpoint(udp::v4(), port));
udp::socket sock2(io_service, udp::endpoint(udp::v4(), 0));
for (;;)
{
char data[max_length];
udp::endpoint sender_endpoint;
size_t length = sock.receive_from(
boost::asio::buffer(data, max_length), sender_endpoint);
printf("Got data, sending response to %s:%d\n", sender_endpoint.address().to_string().c_str(), sender_endpoint.port());
sock2.send_to(boost::asio::buffer(data, length), sender_endpoint);
}
}
int main(int argc, char* argv[])
{
try
{
if (argc != 2)
{
std::cerr << "Usage: blocking_udp_echo_server <port>\n";
return 1;
}
boost::asio::io_service io_service;
using namespace std; // For atoi.
server(io_service, atoi(argv[1]));
}
catch (std::exception& e)
{
std::cerr << "Exception: " << e.what() << "\n";
}
return 0;
}