gpt4 book ai didi

java - 关于InetAddress "isReachable"方法

转载 作者:行者123 更新时间:2023-12-01 15:19:58 29 4
gpt4 key购买 nike

为了开发设备监控系统,我使用 InetAdress isReachable 方法来了解网络中的设备是否在线。我正在使用 ScheduledExecutorService 以及包含同时 ping icmp 设备的设备列表。

现在,如果设备数量较少(例如 60 个设备),由 ScheduledExecutorService 使用 10 个线程池进行 ping,则可以正常工作。意味着结果将正确显示设备状态。这里isReachable 的超时时间超过 5000 毫秒。如果设备数量增加到 80,即使设备在线,某些设备也会通过 isReachable 方法显示离线状态。如果我将 isReachable 方法的超时时间增加到10000 ms,设备状态有更好的机会获得正确的状态。

在这些设备中,大多数设备都是基于 Linux 的系统,并且 isReachable 始终为它们返回正确的状态,但对于 Windows,行为是不可预测的。我想确保网络上的设备始终处于正确的状态。还可以通过启动 java 进程来查看在线设备的退出值 0 来替代机制。

例如“Process proc = new ProcessBuilder("ping", host).start();

那么,专家会给出什么建议呢?如上所述,使用 Process 检查设备状态是否会比 isReachable 调用更好、更可靠?

最佳答案

在子进程中运行 ping 不太可能让事情变得更好;虽然 Java 进程的负载会减少,但您只需在一台机器内移动它即可。 (此外,我不确定您是否真的可以从一台主机同时 ping 多台计算机,因为 ICMP ECHO(ping 的标准化核心)的工作方式。)您可能遇到的另一个问题是一台机器可以响应 ping,但实际上无法有效可达;我见过一些机器,其中内核正在工作(使其可 ping 通),但没有正在工作的用户进程,您可以轻松想象机器上特别有趣的服务已关闭。 (此外,某些防火墙会阻止 ping。)最好使用某种与该计算机上运行的实际服务建立的无操作连接来实际检测每台计算机是否正在工作。

如果您确实想跟踪大量计算机的状态,则应该考虑使用专为该任务设计的软件(例如 Nagios)。对于ServerFault来说,这更是一个问题。比堆栈溢出...

关于java - 关于InetAddress "isReachable"方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11079646/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com