Почему этот улучшенный код asio не работает правильно? - PullRequest
1 голос
/ 20 сентября 2010

Этот ускоренный сервер 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;
}

1 Ответ

0 голосов
/ 21 сентября 2010

Снова отвечаю на мой вопрос!

Убедитесь, что на другом компьютере не запущено программное обеспечение брандмауэра !. Оказывается, на машине с Windows, работающей в виртуальной машине, был запущен брандмауэр Windows.

Я не сразу заподозрил это, потому что когда я отправлял ответ UDP на исходный сокет, используя номер порта, переданный на сервер, он работал.

Я полагаю, что брандмауэр Windows поддерживает некоторое состояние.

...