实现shell多进程局域网扫描

来源:互联网 发布:淘宝秒杀群找商家合作 编辑:程序博客网 时间:2024/05/17 01:41

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

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

#!/bin/bashfor i in ` seq 255 `do        ping -c1  192.168.1.$i && echo 192.168.1.$i >> hostsdone

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

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

问题如下:

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

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

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

0 0