news 2026/5/23 12:31:25

Java广播 —如何利用广播做服务发现

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Java广播 —如何利用广播做服务发现

通过广播可以在局域网内广播信息,广播接收端通过监听广播信息,可以自动发现局域网内所有的设备/服务信息。

1. 发送广播

在 Java 中通过将 DatagramSocket 设置setBroadcast(true)来发送广播。

DatagramSocketsocket=newDatagramSocket();socket.setBroadcast(true);
// 广播内容byte[]broadcastContent="广播内容".getBytes();// 发送广播的指定端口intbroadcastPort=12135;// 发送广播的地址InetAddressbroadcastAddress=InetAddress.getByName("255.255.255.255");// 构建广播数据包DatagramPacketpacket=newDatagramPacket(broadcastContent,broadcastContent.length,broadcastAddress,broadcastPort);socket.send(pocket);
  • broadcastAddress(255.255.255.255): 表示发送到本地网络中的所有设备,并且不会被路由器转发到其他网络,意味着该网络数据包会广播到局域网中的所有设备。
  • broadcastPort(12135): 表示发送到该端口,广播数据包只能发送到一个端口,不能发送到多个端口。

除了通过 255.255.255.255 也可以设置发送到指定的子网的所有主机。如: 192.168.1.255。
可以通过以下方式获取当前主机所在子网的所有广播地址列表。

privatestaticList<InetAddress>listAllBroadcastAddresses()throwsSocketException{List<InetAddress>broadcastList=newArrayList<>();// 获取所有的网络接口Enumeration<NetworkInterface>interfaces=NetworkInterface.getNetworkInterfaces();while(interfaces.hasMoreElements()){NetworkInterfacenetworkInterface=interfaces.nextElement();// 剔除本地回环地址(127.0.0.1) 以及未启用的接口if(networkInterface.isLoopback()||!networkInterface.isUp()){continue;}// 提取每个地址的广播地址networkInterface.getInterfaceAddresses().stream().map(InterfaceAddress::getBroadcast).filter(Objects::nonNull).forEach(broadcastList::add);}returnbroadcastList;}

这样就可以从列表中选择向哪一个子网发送广播信息,或是遍历列表都发送。

2. 接收广播

接收广播同样是通过 DatagramSocket 类,但不需要设置为广播模式,需要监听本地端口,这个端口也就是广播发送端广播的端口。

// 监听端口DatagramSocketsocket=newDatagramSocket(12135);byte[]receiveBuff=newbyte[1024];DatagramPacketpacket=newDatagramPacket(receiveBuff,receiveBuff.length);// 阻塞式等待接收广播信息socket.receive(packet);// 解析广播信息StringreceiveContent=newString(packet.getData(),0,packet.getLength());System.out.println("接收到广播信息 :"+receiveContent);

3. 应用

通过广播的方式,我们可以做到局域网内的自动服务发现。比如以下技术都是通过广播来做到的

  1. DHCP, 客户端通过广播 255.255.255.255,67端口发现DHCP服务器。
  2. 打印机,物联网设备的设备发现
  3. 局域网游戏服务器的服务发现

3.1 服务发现流程

  1. 客户端向局域网的指定端口定期发送广播信息。
  2. 服务端在指定端口监听所有客户端的广播信息。
  3. 服务端解析接收到的广播信息,获取与客户端的通信方式(通信方式自定义,可以通过TCP协议,HTTP协议…)
  4. 以TCP协议为例,客户端发送的数据包中应该有通信端口,服务端通过该端口与客户端进行双向通信。
  5. 服务端维护已连接的客户端列表。
服务发现端局域网客户端服务发现端局域网客户端定期发送广播数据包监听广播数据包监听到广播数据包解析数据包,获取通信端口与客户端IP请求与客户端通信响应服务端请求更新客户端列表客户端下线请求更新客户端列表

3.2 注意点

  1. 广播的数据意味着可以被网络中所有的设备监听到,因此可以在广播数据包时做好数据加密。
  2. 在客户端与服务端进行双向连接时做身份验证
  3. 控制广播频率,如30秒一次,高频广播会占用带宽。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/21 9:57:07

大数据领域分布式计算的性能优化策略

大数据分布式计算性能优化&#xff1a;从“堵车”到“通途”的系统调校指南 关键词 分布式计算、性能优化、数据本地化、资源调度、Shuffle优化、并行度调整、容错机制 摘要 当你用分布式集群处理100TB日志时&#xff0c;有没有遇到过这样的场景&#xff1a;任务卡了6小时还没跑…

作者头像 李华
网站建设 2026/5/20 10:50:16

吐血推荐9个AI论文写作软件,专科生毕业论文轻松搞定!

吐血推荐9个AI论文写作软件&#xff0c;专科生毕业论文轻松搞定&#xff01; AI工具助力论文写作&#xff0c;专科生也能轻松应对 在当前的学术环境中&#xff0c;AI工具已经成为许多学生不可或缺的助手&#xff0c;尤其是在论文写作方面。对于专科生来说&#xff0c;撰写一篇符…

作者头像 李华
网站建设 2026/5/9 19:33:35

第五届AIGC开发者大会年度对话:超级算力如何打造超级产品?

作者&#xff1a;王聪彬 现如今&#xff0c;算力正从技术底座走向产品前台&#xff0c;开始塑造产品形态和应用边界。随着优质算力在云、边、端环境中普及&#xff0c;企业和开发者开始关注如何将算力、高性能计算能力和软件平台结合起来&#xff0c;把技术潜力转化为可用、可落…

作者头像 李华
网站建设 2026/5/6 1:20:57

从“企业AI”到“AI企业”,这场会议把AI落地路径讲透了

作者&#xff1a;于佳卉 在2026第五届AIGC开发者大会上&#xff0c;由至顶科技主办的“企业AI应用与本地算力实践”分论坛成为现场焦点之一。来自企业级AI服务、前沿模型与推理技术、产业应用实践等领域的嘉宾&#xff0c;从产业趋势、工程方法、组织变革等多个维度&#xff0c…

作者头像 李华