多进程秒ping内网主机

之前要写个探测内网主机存活的bash脚本,一直没写明白,写完文件监控之后突然就写明白了

代码:

#!/bin/bash

# 定义要扫描的IP地址范围
subnet="192.168.$1."
start_ip=1
end_ip=254

# 创建一个空临时文件来保存扫描结果
tmp_file=$(mktemp)

# 循环遍历IP地址范围,并将 ping 命令放入后台执行
for ((ip=$start_ip; ip<=$end_ip; ip++)); do
  target_ip="$subnet$ip"
  
  # 使用 ping 命令检测主机是否在线,并将结果保存到临时文件
  ping -c 1 -W 1 $target_ip >/dev/null 2>&1 && echo "主机 $target_ip 在线" >> "$tmp_file" &
done

# 等待所有后台进程执行完成
wait

# 输出扫描结果
cat "$tmp_file"

# 删除临时文件
rm "$tmp_file"

直接进程拉满,秒出结果

 

 原理就是用ping探测主机是否存活,并且指定只发送一个数据包,超时为一秒,然后用“&”来实现多进程,用wait等所有ping结束再输出结果

 还发现个挺别致的小东西,照着msf里抄的

贴在for循环前边就行:

echo -e "\033[36m开始扫描"
echo "       \   ,__,"
echo "        \  (oo)____"
echo "           (__)    )\ "
echo "              ||--|| *"
echo "--------------------"

 

posted @ 2023-08-01 10:46  TheBlackEagle  阅读(29)  评论(0)    收藏  举报