43 lines
840 B
Bash
Executable File
43 lines
840 B
Bash
Executable File
#!/bin/bash
|
|
|
|
export LANG=en_US.UTF-8
|
|
LOG_PATH="/var/log/monitor"
|
|
LOG_NAME="io"
|
|
SAR_INTERVAL=20
|
|
SAR_COUNT=6
|
|
|
|
function Init {
|
|
local self_count=$(pgrep -cx "$(basename $0)")
|
|
[ 0 -eq $? ] || exit 1
|
|
[ 1 -eq $self_count ] || exit 1
|
|
type sar > /dev/null || exit 1
|
|
mkdir -p $LOG_PATH || exit 1
|
|
}
|
|
|
|
function Log {
|
|
local msg="$1"
|
|
local log_time="$(date +'%F %T')"
|
|
local log_file="$LOG_PATH/$LOG_NAME-${log_time% *}.log"
|
|
echo "$log_time $msg" >> $log_file
|
|
cd $LOG_PATH && ls ${LOG_NAME}-* 2>/dev/null \
|
|
| head -n -7 | xargs rm -f
|
|
}
|
|
|
|
function GetIOInfo {
|
|
sar -dp $SAR_INTERVAL $SAR_COUNT | grep '^Average' \
|
|
| tail -n +2 \
|
|
| awk '{print $2,$3,-$4/2,$5/2,$8,$10}'
|
|
}
|
|
|
|
function Main {
|
|
local line=
|
|
GetIOInfo | while read line; do
|
|
Log "$line"
|
|
done
|
|
}
|
|
|
|
# start
|
|
Init
|
|
Main
|
|
|