实现shell多进程局域网扫描

本文通过一个局域网扫描脚本实例,展示了如何优化Shell脚本以提高其效率和实用性。作者分享了从顺序执行到并行处理的转变过程,并讨论了在不同网络环境下可能遇到的问题。

  今日突发奇想翻出原来的脚本,发现原来自己写的好多脚本只是实现了基本的功能,却没有考虑到实用性和可用性.

就像这个刚开始学习shell的时候写的一个局域网扫描脚本:

#!/bin/bash
for i in ` seq 255 `
do
        ping -c1  192.168.1.$i && echo 192.168.1.$i >> hosts
done

别看这个脚本只有短短的四行,但是暴露出的问题可是真的不少哭

就跟翻看自己原来QQ空间中的各种日志说说的感觉是一样的,(这东西怎么可能是我写的!!)

问题如下:

  1. 遇到空IP超时时间过长.
  2. ping命令是顺序执行,而且上下两条没有依赖关系,应该并行执行.
改写如下:
for i in ` seq 255 `
do
        ping -c1 -w1 192.168.1.$i && echo 192.168.1.$i >> hosts &
done
wait

-w选项指定ping命令的deadline为1秒
for配合& 将所有的ping放在后台执行,实现了多进程
wait命令等待所有后台进程执行结束后退出.

这个多进程只是单纯的解决了这一个问题,而且适用环境不多,注意不要在B类网下测试哟
一下子往后台放255*255个进程会出现意想不到的结果哦大笑

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值