DatagramPacket与DatagramSocket

DatagramPacket与DatagramSocket

背景

系统需要用UDP接收三类数据报文(不同长度),接收到对十进制转换成十六进制进行在线解析,进行一些校验并标记异常。

实现方式

发送端

DatagramSocket datagramSocket = new DatagramSocket();
DatagramPacket datagramPacket = new DatagramPacket(new byte[每类数据固定长度], new byte[1024].length, InetAddress.getByName("127.0.0.1"), 9999);
datagramSocket.send(datagramPacket);

接收端

DatagramSocket datagramSocket = new DatagramSocket(9999);
//按三类数据中最大长度来接收
DatagramPacket datagramPacket = new DatagramPacket(new byte[1400], new byte[1400].length);
//接收数据
datagramSocket.receive(datagramPacket);
//接收到的内容
recvByte = datagramPacket.getData();
//后续十进制转十六进制,对头字进行校验,进行在线解析

问题

发现进行在线解析每一条有效数据耗时150ms左右,发送端发送完数据进行关闭,接收端丢包,发送60万条数据,仅接收到8万条数据

采用多线程的方式对数据进行接收和对数据进行在线解析,但是后续做行为分析时数据是无序的报错率很多。

缩短每条数据的耗时发送kafka进行异步解耦操作,将处理一条数据的时间缩短到10ms-20ms,实现了可以接收40万条,但是还是丢了很多数据

通过写文件的方式,将在线解析转换成离线文件,再进行解析,文件过大,对文件不好操作,每条都写入,只能写入2万条

通过批量写文件的方式,每次将接收到的数据放到数组中,统一写入文件,但是会丢失最后几次的数据

最后通过队列,将接收到的数据放到队列中,开辟新线程对队列中的数据进行弹出消费,进行后续的解析

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值