这几天需要做Linux的TCP端口检查脚本,发现netstat、nc命令虽好,但不够直观,而且端口多了检查起来有点麻烦,动手学做了两个脚本。一个是用参数形式检查端口情况,另一个使用配置文件扫描端口。记录下来方便以后使用。
一、nc_check.sh
#!/bin/bashcat ./check_port|while read linedo nc -z `uname -n` $line >/dev/null 2>&1 if [ $? -eq 0 ];then echo "$line OK." else echo "$line Failed." fidone
使用前在当前目录下建立一个check_port的文件,内容为:
cat check_port123345456
所有TCP检测端口按照每行一个记录到文件内。执行效果:
[root@ABC ~]#. nc_check123 OK345 OK456 Failed
程序把列表内所有端口检查一遍,成功的OK,失败的Failed
二、netstat_check.sh
#!/bin/bashdeclare -a CHK_TCP_CMD=`netstat -tln|egrep 0.0.0.0|awk '{print $4}'|awk -F: '{print $2}'|sort -n`declare -a PORT_NO_EXISTSdeclare -i CURRENT_PORT=0for TCP_PORT in $@do #IS NUMBER expr "$TCP_PORT" + 0 >/dev/null 2>&1 if [ "$?" != "0" ];then echo "$TCP_PORT not a number." exit 1 fi PORT_NO_EXISTS[$CURRENT_PORT]=$TCP_PORT for LSN_PORT in $CHK_TCP_CMD do if [ $TCP_PORT == $LSN_PORT ];then unset PORT_NO_EXISTS[$CURRENT_PORT] break fi done ((CURRENT_PORT++))doneif [ ${#PORT_NO_EXISTS[@]} -gt 0 ];then echo "TCP ports ${PORT_NO_EXISTS[@]} failed." exit 1fiexit 0
使用时直接在脚本后添加端口号作为参数,若扫描多个端口号,则每个端口号以空格隔开。若其中一个参数非数字,则程序终止。执行效果:
[root@ABC ~]#./netstat_check.sh 789
扫描到的端口无输出。
[root@ABC ~]#./netstat_check.sh 123 456 789TCP port 123 456 failed.
程序把所有失败的端口罗列出来。
[root@ABC ~]#./netstat_check.sh 123 hello 456hello not a number.
不是数字的程序输出错误。