java socket问题,不会监听多个数据报包

时间:2010-01-22 12:42:57

标签: java sockets udp package datagram

我正在创建一个服务器(现在称为Server1),它与我拥有的另一台服务器(现在称为Server2)进行通信。

  • Server1向Server2发送datagrampackage。
  • Server2应该发回两个数据报包,但我只得到一个。
  • Server2不是问题,并发送两个包。

我使用Wireshark来嗅探离开的包并来到Server1。

  

套餐一(来自wireshark):   “5955 11994.023974 192.168.1.3 192.168.1.2 UDP源   端口:50000目标端口:50004“

     

套餐二(来自wireshark):   5958 11994.045830 192.168.1.3 192.168.1.2 ICMP目的地不可达(端口不可达)

Server1运行一个正在侦听数据报包的线程。

代码服务器1:

     while (m_keepRunning)
    {
        try
        {
         TermMsg receivedMessage = null;
         receivedMessage = receive();   //See this function further down
         if (receivedMessage != null)
            {
                if (receivedMessage.getMsgType().equals(TermMsgType.ACK))
                {
                 System.out.println("This is an ack!");
                }
                else
                {

                 System.out.println("This is a response");
                }
            }
         else
         {
          System.out.println("This is nothing");
         }

        }

接收功能:

      private TermMsg receive() throws IOException, TermMsgException
{
  byte[] inBuf = new byte[BUF_SIZE_RX];
  DatagramPacket inData = new DatagramPacket(inBuf, BUF_SIZE_RX);

    if(true == firstEncounter)
    {
            StartMessage startReq = getStartMsg(false);
     DatagramPacket p = makeDatagramP(startReq);
     socket.send(p);
     firstEncounter = false;
    }

    socket.receive(inData);
    if (inData.getLength() > 0)
    {
        Msg msg;
        try
        {
            msg = Msg.createFromUdp(inData.getData());
            return msg;
        }
        catch (TermMsgException e1)
        {
            return null;
        }
    }
    else
    {
     try
        {
            Thread.sleep(100);
        }
        catch (InterruptedException e)
        {

        }
        return null;
    }
}

有没有人有线索? 顺便说一句......我也用:

DatagramSocket socket;
try {
  socket = new DatagramSocket(50004);
}

我是否必须使用服务器套接字来监听多个数据报包?

要点: - 端口无法访问 - 无法收到第二包

希望有人可以帮助我。 提前致谢

1 个答案:

答案 0 :(得分:1)

正如在该问题的评论中已经提到的,第一个问题是您假设以下两行是两个正在发送的UDP数据包。

Package one(from wireshark): "5955 11994.023974 192.168.1.3 192.168.1.2 UDP Source port: 50000 Destination port: 50004"

Package two(from wireshark): 5958 11994.045830 192.168.1.3 192.168.1.2 ICMP Destination unreachable (Port unreachable)

实际上,这可能是一个不完整的痕迹,因为它显示了两个包:

Package one(from wireshark): "5955 11994.023974 192.168.1.3 192.168.1.2 UDP Source port: 50000 Destination port: 50004"

这是一个UDP数据包,从server2(192.168.1.3)到server1(192.168.1.2)。它将被发送到server1上的端口50004。

Package two(from wireshark): 5958 11994.045830 192.168.1.3 192.168.1.2 ICMP Destination unreachable (Port unreachable)

这是从server2发送到server1的控制消息,表示由于目标端口未打开而无法传送先前的数据包。这是从server1到server2的先前数据包传递尝试的答案,该尝试不起作用。这可能有助于解释为什么你没有得到你期望的所有数据包?