文章目录
- 获取ping的时延数据并分析网络情况
- |、||、&、&&辨析
- tee
- tail
- killall
获取ping的时延数据并分析网络情况
网络情况经常让我们头疼,每次都需要手动在终端ping太麻烦了,不如写个脚本ping并将数据带上时间戳存入文件,然后也可以分析哪个时间段网络比较差。
创建一个demo.sh
文件:
#!/bin/bash
# 清理日志
net_path="./network/"# 目录存在,删除修改时间为1天前的文件
if [ -d "${net_path}" ]; then
echo start delete log 1 days ago...find "${net_path}"/* -name '*.txt' -mtime +1 -exec rm -rf {} \;
echo end delete log ...
fioutput_file="./network/output.txt"
# 设置目标主机
target_host="baidu.com"# 定义函数获取当前时间戳
get_timestamp() {date +"%Y-%m-%d %H:%M:%S"
}# 循环执行ping命令
while true; do# 获取当前时间戳timestamp=$(get_timestamp)# 执行ping命令并抓取延迟时间ping_result=$(ping -c 1 $target_host | grep time= | awk -F 'time=' '{print $2}' | cut -d ' ' -f 1)# 输出带有时间戳的ping结果echo "$timestamp - Ping: $ping_result ms"echo "$timestamp - Ping: $ping_result ms" >> "$output_file"# 等待1秒后继续执行sleep 1
done
时延数据会存入output.txt
中,然后也会自动删除前一天的文件。
最后,可将txt导入excel,生成图表看什么时候网络较差:
更新后:
#!/bin/bash
net_path="./network/"
target_host="baidu.com" # need config# if folder exist
if [ ! -d "$net_path" ]; thenmkdir -p "$net_path"echo "folder not exist: $net_path"
elseecho "folder exist: $net_path"
fi# get timestamp
get_timestamp() {date +"%Y-%m-%d %H:%M:%S"
}# autoclean
if [ -d "${net_path}" ]; then
echo start delete log 1 days ago...find "${net_path}"/* -name '*.txt' -mtime +0 -exec rm -rf {} \;
echo end delete log ...
fi# get ping value
filename_prefix="${net_path}ping"
timestamp=$(get_timestamp)
filename="${filename_prefix}_${timestamp}.txt"while true; doping_result=$(ping -c 1 $target_host | grep time= | awk -F 'time=' '{print $2}' | cut -d ' ' -f 1)echo "$timestamp - Ping: $ping_result ms" # displayecho "$timestamp - Ping: $ping_result ms" >> "$filename" # logsleep 1
done
|、||、&、&&辨析
竖线‘|’在linux中是管道符的意思,将‘|’前面命令的输出作为’|'后面的输入;
双竖线‘||’,用双竖线‘||’分割的多条命令,执行的时候遵循如下规则:如果前一条命令为真,则后面的命令不会执行,如果前一条命令为假,则继续执行后面的命令;
&同时执行多条命令,不管命令是否执行成功;
&&可同时执行多条命令,当碰到执行错误的命令时,将不再执行后面的命令。如果一直没有错误的,则执行完毕。
用的时候,先记住‘|’是管道符,&是并行执行,‘||’和&&分别是他们的进阶版。
tee
tee是一种文件管理命令,tee命令用于读取标准输入的数据,并将其内容输出成文件。如:
tee 1.txt
ls -l | tee 2.txt
可用于打印终端输出和日志等。
tail
tail 命令可用于查看文件的内容,有一个常用的参数-f,常用于查阅正在改变的日志文件。如:
tail 1.txt
tail -f 1.txt
可用于查看日志文件变化。
killall
kill 命令杀死指定进程 PID,需要配合 ps 使用,而 killall 直接对进程对名字进行操作,更加方便。kill后常跟PID代号,而killall后常跟进程名。如:
kill -9 8178
killall -9 bash
killall -9 roscore
killall -9 rosmaster
可用于退出进程。
以上。