在Linux中,如何使用脚本,实现判断 192.168.1.0/24 网络里,当前在线的 IP 有哪些?能ping 通则 认为在线。

简介: 在Linux中,如何使用脚本,实现判断 192.168.1.0/24 网络里,当前在线的 IP 有哪些?能ping 通则 认为在线。

要在Linux中编写一个脚本来判断192.168.1.0/24网络中哪些IP地址是在线的(即可以ping通),你可以使用Shell脚本结合ping命令来实现。下面是一个简单的示例脚本,它会遍历该子网内的所有IP地址,并打印出可以ping通的IP。

请注意,在运行此脚本之前,确保你有执行该操作的权限,并理解ping大量IP可能会对网络造成一定负担。

#!/bin/bash
# 定义网络和掩码
NETWORK=192.168.1
MASK=24
# 计算子网的第一个和最后一个IP
FIRST_IP=$(($NETWORK<<24))&((1<<32)-1-$((1<<(32-$MASK))))
LAST_IP=$((FIRST_IP | (1<<(32-$MASK))-1))
# 遍历IP范围并ping每个IP
for ip in $(seq $FIRST_IP $LAST_IP); do
# 将数字IP转换为点分十进制格式
    PINGABLE_IP=$(printf "%d.%d.%d.%d" $(($ip>>24&0xFF)) $(($ip>>16&0xFF)) $(($ip>>8&0xFF)) $(($ip&0xFF)))
# 尝试ping并检查返回值,通常0表示成功
    ping -c 1 -W 1 $PINGABLE_IP > /dev/null 2>&1
if [ $? -eq 0 ]; then
echo "$PINGABLE_IP is online"
fi
done

保存这个脚本到文件中,例如check_ips.sh,然后给它执行权限并运行:

chmod +x check_ips.sh
./check_ips.sh

解释脚本关键部分:

  • #!/bin/bash 定义了脚本使用的Shell类型。
  • $NETWORK$MASK 变量存储了网络地址和子网掩码信息。
  • 使用位运算计算子网的第一个和最后一个IP地址。
  • seq 命令生成IP地址序列。
  • printf 将计算出的数字IP转换为点分十进制格式。
  • ping -c 1 -W 1 指令尝试向每个IP地址发送一个ICMP请求,并设置超时为1秒。
  • $? 存储上一条命令的退出状态,如果ping成功,则其值为0。
  • 根据ping的结果,脚本输出相应的IP地址是否在线的信息。

综上所述,请根据实际情况调整脚本中的参数,比如增加或减少超时时间等。

相关文章
|
7月前
|
负载均衡 网络协议 Linux
网络ping不通到底有多少原因?一文搞明白!
网络ping不通是网络中出现频率最高的故障之一,同时也是最让人抓狂的故障,谁没遇到过?今天就和你细说下ping不通的原因,看看能不能和你遇到的情况对上号。
6135 0
|
8月前
|
JSON 监控 API
在线网络PING接口检测服务器连通状态免费API教程
接口盒子提供免费PING检测API,可测试域名或IP的连通性与响应速度,支持指定地域节点,适用于服务器运维和网络监控。
1207 0
|
5月前
|
网络协议 Linux 虚拟化
配置VM网络:如何设定静态IP以访问主机IP和互联网
以上就是设定虚拟机网络和静态IP地址的基本步骤。需要注意的是,这些步骤可能会因为虚拟机软件、操作系统以及网络环境的不同而有所差异。在进行设定时,应根据具体情况进行调整。
464 10
|
6月前
|
安全 Linux 网络安全
Nipper 3.9.0 for Windows & Linux - 网络设备漏洞评估
Nipper 3.9.0 for Windows & Linux - 网络设备漏洞评估
195 0
Nipper 3.9.0 for Windows & Linux - 网络设备漏洞评估
|
7月前
|
运维 Linux 开发者
Linux系统中使用Python的ping3库进行网络连通性测试
以上步骤展示了如何利用 Python 的 `ping3` 库来检测网络连通性,并且提供了基本错误处理方法以确保程序能够优雅地处理各种意外情形。通过简洁明快、易读易懂、实操性强等特点使得该方法非常适合开发者或系统管理员快速集成至自动化工具链之内进行日常运维任务之需求满足。
489 18
|
7月前
|
网络协议 关系型数据库 Linux
【App Service Linux】在Linux App Service中安装 tcpdump 并抓取网络包
在App Service for Linux环境中,无法像Windows一样直接使用网络排查工具抓包。本文介绍了如何通过TCPDUMP在Linux环境下抓取网络包,包括SSH进入容器、安装tcpdump、执行抓包命令及下载分析文件的完整操作步骤。
377 5
|
8月前
|
监控 安全 Go
使用Go语言构建网络IP层安全防护
在Go语言中构建网络IP层安全防护是一项需求明确的任务,考虑到高性能、并发和跨平台的优势,Go是构建此类安全系统的合适选择。通过紧密遵循上述步骤并结合最佳实践,可以构建一个强大的网络防护系统,以保障数字环境的安全完整。
185 12
|
8月前
|
Web App开发 网络协议 Linux
【Linux】网络基础
TCP/IP五层模型是网络通信的基础框架,将复杂的数据传输过程分为物理层、数据链路层、网络层、传输层和应用层,每层各司其职,协同完成远程通信。该模型确保了不同设备和网络之间的互联互通,是现代互联网运行的核心机制。
866 5