简单的shell脚本第二版

经过各位老板的指点我修改了部分内容使其更加完善        原文链接  http://www.178linux.com/70381

/bin/bash
declare -i Inet
declare -i Snet
[[ $1 =~ ((2[0-4][0-9]|25[0-5]|1?[0-9]?[0-9])\.){3}(2[0-4][0-9]|25[0-5]|1?[0-9]?[0-9])\/(2[4-9]|3[0-2]) ]]  #正则表达式验证是否为正确格式
if [ $? -ne 0 ] ;then                               #判断格式是否配正确匹配
{
echo ” Usage:$0 172.18.0.0/24-32.”              #如果格式未被正确匹配返回250状态码,并提示使用方法
exit 250
}
fi
Inet=`echo “$1″ | cut -d”.” -f4 | cut -d”/” -f1`   #获取Ip地址位
Iseg=`echo “$1″ | cut -d”/” -f2`                   #获取子网掩码位
Ipv4=`echo “$1″ | cut -d”.” -f1,2,3`               #获取主机位
let Smask=32-$Iseg                                   #计算子网掩码反掩码位数
Sips=$[2**$Smask]                                   #计算出指定网络的IP数
Snet=$[ $Inet + $Sips -1 ]                           #从指定主机数到输出的主机个数
[ $Snet -gt 255 ] && Sips=$[ 256 – $Inet ] && Shosts=255 || Shosts=$[ $Inet + $Sips -1 ]
echo “反向子网掩码位为:$Smask”                     #输出反掩码位数
echo “要查找的地址数为:$Sips”                       #输出主机个数
echo “子网掩码的位数为:$Iseg”                       #输出子网掩码
echo “Ipv4的首个地址为:${Ipv4}.$Inet” #输出网络地址位
echo “查看的网段地址为:${Ipv4}.${Inet}-${Ipv4}.${Shosts}” #输出匹配的网络位
if [ $Snet -gt 255 ] ;then                           #当地址数溢出时的补救措施    
{
Snet=255                                        #主机数强制为255个
}
fi
for i in `seq $Inet $Snet`;                         #for循环从指定主机开始到指定网段结束的IP个数
do

ping -c1 -W1 $Ipv4.$i >/dev/null 2>&1  && echo -e  “\033[32m$Ipv4.$i is \tup \033[0m” || echo -e  “$Ipv4.$i is\033[31m \tdown \033[0m”
read  -dq -s -t 1 wode && exit                        #read接受到用户输入的q后终止循环并退出脚本
#ping 判断主机是在线还是 不在线
done
unset Inet Iseq Ipv4 wjy  Smask Sips Snet  wode         #释放上边使用到的变量


上个版本最大的问题是  只要脚本开始就无法终止脚本  现在按q键可以快退出脚本

正则表达式匹配也不规范  显示的网段和主机个数也有问题

这个脚本适合用子网掩码进行划分过的网络  可以指定任意网段的以子网掩码进行划分的主机


原创文章,作者:wode,如若转载,请注明出处:http://www.178linux.com/71409

(0)
wodewode
上一篇 2017-03-19 21:07
下一篇 2017-03-20 14:41

相关推荐

  • 三.Linux博客-2016年7月24日帮助、history、别名、tree

    格式说明: 操作 概念 命令 说明及举例 三-1.帮助、history、别名、tree touch /etc/nologin 使普通用户不能登录(创建了一个文件,删掉就可以登陆)   ll /etc/nologin 查看那个文件 -rm -f /etc/  删…

    Linux干货 2016-08-23
  • awk用法进阶

    一、控制语句 1 if-else语句        使用场景:对awk取得的整行或某个字段做条件判断        语法:         &nbsp…

    Linux干货 2016-09-21
  • 网络管理之配置文件及一些命令的应用

    IP配置、信息、相关命令    IP地址     它们可唯一标识 IP 网络中的每台设备     每台主机(计算机、网络设备、外围设备)必须具有唯一的地址     IP 地址由两部分组成:   &nb…

    Linux干货 2016-09-22
  • 文本处理三剑客之sed

    概述     经过上篇对正则表达式和grep相关内容的学习,我们对文本处理有了一个初步的认识,本篇将简要介绍一下文本处理三剑客之sed。具体分为以下几个部分:     1、sed原理概述     2、sed命令详解 第一部分 &n…

    Linux干货 2016-08-10
  • 文件权限

    一、文件权限        linux系统中文件众多,针对不同的文件面向的对象不同,因此对其设置的权限各不相同,那么我们来对文件设置权限呢?               …

    Linux干货 2016-08-08