Linux Shell脚本实现批量PING测试

简介: Linux Shell脚本实现批量PING测试

Linux Shell脚本实现批量PING测试

需求:
通过Linux服务器定时ping验证目标IP地址连通情况。
目标IP地址以TXT文件方式存储在本地。
生成的测试记录包含测试时间、目标IP地址、连通情况。

1、测试目的IP地址列表

39.156.66.18
203.119.129.109
111.30.164.236

image

2、批量PING脚本

#!/bin/bash
#
#获取当前时间
datetimevar=`date "+%Y-%m-%d %H:%M:%S"`
#读取IP列表行数
lineNumber=`cat iplist.txt |wc -l`
#设置计数参数
count=0
#循环读取IP并测试
for i in `cat ./iplist.txt`
    do
        #计数器
        count=$((count+1))
        #控制台打印当前进度
        echo "${i} ${count}/${lineNumber}"
        #PING并保留丢包数
        p=`ping -c 1 $i|grep loss|awk '{print $6}'|awk -F "%" '{print $1}'`
            #因为只PING一次,丢包数为0则表示成功,否则失败
            if [ $p -eq 0 ]
                then
                    echo "${datetimevar}|${i}|true" >> ./ipcheckdown.txt
                else
                    echo "${datetimevar}|${i}|fail" >> ./ipcheckdown.txt
            fi
    done

image

3、设置脚本文件运行权限

chmod +x pingtest.sh
image

4、执行脚本(回显执行进度)

./pingtest.sh
image

5、查看结果

cat ipcheckdown.txt
image

6、添加定时任务,设置每分钟运行一次

crontab -e
*/1 * * * * /root/pingtest.sh
image

7、运行情况(是否显示与具体系统设置有关)

自动执行后系统提示“您在 /var/spool/mail/root 中有新邮件”
image

查看结果
image

8、备注

通过Windows系统编辑的文件在Linux中执行时,若由于文件格式问题导致报错,例如:
(1)脚本字符格式异常:
【/bin/bash^M: 坏的解释器: 没有那个文件或目录】
(2)IP列表格式问题导致脚本读取IP异常:
【:未知的名称或服务- 5 ./pingtest.sh第17行•••】
(3)问题原因:
在Windows下每一行结尾是nr,而Linux下则是n,所以才会有多出来的r。
修改方式:
使用指令 sed -i 's/\r$//' 文件名,将上面的指令会把文件中的r 替换成空白。

Yunxi.D
2020-06-04
2020-06-10(追加)

目录
相关文章
|
1月前
|
SQL 安全 Linux
Metasploit Pro 4.22.8-20251014 (Linux, Windows) - 专业渗透测试框架
Metasploit Pro 4.22.8-20251014 (Linux, Windows) - 专业渗透测试框架
116 1
Metasploit Pro 4.22.8-20251014 (Linux, Windows) - 专业渗透测试框架
|
1月前
|
Linux 网络安全 iOS开发
Metasploit Framework 6.4.95 (macOS, Linux, Windows) - 开源渗透测试框架
Metasploit Framework 6.4.95 (macOS, Linux, Windows) - 开源渗透测试框架
180 1
Metasploit Framework 6.4.95 (macOS, Linux, Windows) - 开源渗透测试框架
|
2月前
|
安全 Linux 网络安全
Metasploit Pro 4.22.8-2025091701 (Linux, Windows) - 专业渗透测试框架
Metasploit Pro 4.22.8-2025091701 (Linux, Windows) - 专业渗透测试框架
275 2
Metasploit Pro 4.22.8-2025091701 (Linux, Windows) - 专业渗透测试框架
|
2月前
|
Linux 网络安全 iOS开发
Metasploit Framework 6.4.90 (macOS, Linux, Windows) - 开源渗透测试框架
Metasploit Framework 6.4.90 (macOS, Linux, Windows) - 开源渗透测试框架
379 1
Metasploit Framework 6.4.90 (macOS, Linux, Windows) - 开源渗透测试框架
|
2月前
|
存储 安全 Unix
七、Linux Shell 与脚本基础
别再一遍遍地敲重复的命令了,把它们写进Shell脚本,就能一键搞定。脚本本质上就是个存着一堆命令的文本文件,但要让它“活”起来,有几个关键点:文件开头最好用#!/usr/bin/env bash来指定解释器,并用chmod +x给它执行权限。执行时也有讲究:./script.sh是在一个新“房间”(子Shell)里跑,不影响你;而source script.sh是在当前“房间”里跑,适合用来加载环境变量和配置文件。
419 9
|
2月前
|
存储 Shell Linux
八、Linux Shell 脚本:变量与字符串
Shell脚本里的变量就像一个个贴着标签的“箱子”。装东西(赋值)时,=两边千万不能有空格。用单引号''装进去的东西会原封不动,用双引号""则会让里面的$变量先“变身”再装箱。默认箱子只能在当前“房间”(Shell进程)用,想让隔壁房间(子进程)也能看到,就得给箱子盖个export的“出口”戳。此外,Shell还自带了$?(上条命令的成绩单)和$1(别人递进来的第一个包裹)等许多特殊箱子,非常有用。
310 2
|
2月前
|
安全 Linux 网络安全
Metasploit Framework 6.4.88 (macOS, Linux, Windows) - 开源渗透测试框架
Metasploit Framework 6.4.88 (macOS, Linux, Windows) - 开源渗透测试框架
545 0
|
3月前
|
运维 Linux 开发者
Linux系统中使用Python的ping3库进行网络连通性测试
以上步骤展示了如何利用 Python 的 `ping3` 库来检测网络连通性,并且提供了基本错误处理方法以确保程序能够优雅地处理各种意外情形。通过简洁明快、易读易懂、实操性强等特点使得该方法非常适合开发者或系统管理员快速集成至自动化工具链之内进行日常运维任务之需求满足。
234 18
|
2月前
|
存储 安全 Linux
Kali Linux 2025.3 发布 (Vagrant & Nexmon) - 领先的渗透测试发行版
Kali Linux 2025.3 发布 (Vagrant & Nexmon) - 领先的渗透测试发行版
519 0
|
安全 Linux 测试技术
OpenText Static Application Security Testing (Fortify) 25.3 (macOS, Linux, Windows) - 静态应用安全测试
OpenText Static Application Security Testing (Fortify) 25.3 (macOS, Linux, Windows) - 静态应用安全测试
224 0