java关于UDP的重发机制问题

  • Post author:
  • Post category:java


  1. 远程UDP服务端会一直不停向本地UDP客户端广播信息,本地UDP客户端必须一直接收数据解析后推送到前端;
  2. 远程UDP服务端在接收到本地UDP客户端发送的控制指令后会回复一条相同的指令,并跟上某些数据;
  3. 本地的控制指令随时都可能发出;
  4. 在UDP服务端接收的如30条数据内没有发现所存储的发送指令则视为发送失败,需要重发;

综合上述情况,本想分别使用非阻塞队列ConcurrentLinkedQueue来存储已发送指令,已接收指令,需重发指令,然后在客户端发送指令到服务端之前存储发送指令到已发送指令,接收端立马会poll里面的指令,并开始对比三十条,若三十条数据都不包含发送的指令,那么就将此指令放入需重发队列,发送端再将其进行发送操作(重复存储发送指令,然后发送的操作),但是有个问题就是,若有多条指令,如何对比(由于推送数据到前端要求有较高实时性),并且还要考虑已发送的指令随时都可能增加,现在可能由于太恍惚的原因脑袋一片乱,所以向各位大牛询问一下更好更清晰高效的解决方案。

这种情况下用何种方式来控制本地UDP客户端向远程UDP服务端控制指令的重发。



版权声明:本文为lkj1183209328原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。