Shell脚本 提取sar值 导入数据库
2010-02-10 14:37
288 查看
[root@nagiosbak sarlog]# cat /monitor/nagios/shell/sarlog/scan_sarlog.sh
#!/bin/sh
PDIR=/monitor/nagios/shell/sarlog
runday=$(date +%Y-%m-%d)
TmpDir=/monitor/nagios/tmp
for i in `/bin/cat /monitor/nagios/shell/sarlog/machine.lst`
do
/usr/bin/scp ${PDIR}/sarlog.sh ${i}:/root && /usr/bin/rsh ${i} /root/sarlog.sh &
done
[root@nagiosbak sarlog]# cat sarlog.sh
#!/bin/sh
host=$(hostname)
channel=$(hostname | sed 's/[0-9]//g')
runday=$(date +%Y-%m-%d)
IPhost=$(/sbin/ifconfig | grep 'inet addr:'| grep -v '127.0.0.1' | cut -d: -f2 | awk '{ print $1}')
/usr/bin/sar -u 60 120 > /tmp/$(hostname)-${runday}.txt
/bin/sed '/ \+/s//,/g' /tmp/$(hostname)-${runday}.txt | /bin/sed -n '4,$p' | grep -v Average |awk -F "," '{print "'"$host"'"",""'"$channel"'"",""'"$IPhost"'"",""'"$runday"'"" "$1","$4","$6","$7","$9}' > /tmp/$(hostname)${runday}.txt
rm -rf /tmp/$(hostname)-${runday}.txt
[root@nagiosbak sarlog]# cat /monitor/nagios/shell/sarlog/process_sarlog.sh
#!/bin/sh
PDIR=/monitor/nagios/shell/sarlog
runday=$(date +%Y-%m-%d)
TmpDir=/monitor/nagios/shell/sarlog/log
Machinelst=/monitor/nagios/shell/sarlog/machine.lst
for i in `/bin/cat /monitor/nagios/shell/sarlog/machine.lst`
do
/usr/bin/scp ${i}:/tmp/*${runday}.txt ${TmpDir}
done
/bin/cat ${TmpDir}/*${runday}.txt >> ${TmpDir}/Tmp${runday}.txt
count=1
Line=$(cat ${TmpDir}/Tmp${runday}.txt |wc -l)
>${TmpDir}/Result${runday}.txt
while [ "$count" -le "$Line" ]
do
Idle=$(sed -n "${count}p" ${TmpDir}/Tmp${runday}.txt | awk -F "," '{print $8}')
Busy=`echo "scale=2;100-$Idle"|bc`
sed -n "${count}p" ${TmpDir}/Tmp${runday}.txt | sed "s/$/,$Busy/g" >> ${TmpDir}/${runday}Result.txt
let count=count+1
done
rm -rf ${TmpDir}/*${runday}.txt
/usr/local/mysql/bin/mysql -u root -D nagios -pbj7n48dM <<EOF
load data infile '${TmpDir}/${runday}Result.txt' into table t_daily_stats FIELDS TERMINATED BY ',';
EOF本文出自 “nightmare” 博客,谢绝转载!
#!/bin/sh
PDIR=/monitor/nagios/shell/sarlog
runday=$(date +%Y-%m-%d)
TmpDir=/monitor/nagios/tmp
for i in `/bin/cat /monitor/nagios/shell/sarlog/machine.lst`
do
/usr/bin/scp ${PDIR}/sarlog.sh ${i}:/root && /usr/bin/rsh ${i} /root/sarlog.sh &
done
[root@nagiosbak sarlog]# cat sarlog.sh
#!/bin/sh
host=$(hostname)
channel=$(hostname | sed 's/[0-9]//g')
runday=$(date +%Y-%m-%d)
IPhost=$(/sbin/ifconfig | grep 'inet addr:'| grep -v '127.0.0.1' | cut -d: -f2 | awk '{ print $1}')
/usr/bin/sar -u 60 120 > /tmp/$(hostname)-${runday}.txt
/bin/sed '/ \+/s//,/g' /tmp/$(hostname)-${runday}.txt | /bin/sed -n '4,$p' | grep -v Average |awk -F "," '{print "'"$host"'"",""'"$channel"'"",""'"$IPhost"'"",""'"$runday"'"" "$1","$4","$6","$7","$9}' > /tmp/$(hostname)${runday}.txt
rm -rf /tmp/$(hostname)-${runday}.txt
[root@nagiosbak sarlog]# cat /monitor/nagios/shell/sarlog/process_sarlog.sh
#!/bin/sh
PDIR=/monitor/nagios/shell/sarlog
runday=$(date +%Y-%m-%d)
TmpDir=/monitor/nagios/shell/sarlog/log
Machinelst=/monitor/nagios/shell/sarlog/machine.lst
for i in `/bin/cat /monitor/nagios/shell/sarlog/machine.lst`
do
/usr/bin/scp ${i}:/tmp/*${runday}.txt ${TmpDir}
done
/bin/cat ${TmpDir}/*${runday}.txt >> ${TmpDir}/Tmp${runday}.txt
count=1
Line=$(cat ${TmpDir}/Tmp${runday}.txt |wc -l)
>${TmpDir}/Result${runday}.txt
while [ "$count" -le "$Line" ]
do
Idle=$(sed -n "${count}p" ${TmpDir}/Tmp${runday}.txt | awk -F "," '{print $8}')
Busy=`echo "scale=2;100-$Idle"|bc`
sed -n "${count}p" ${TmpDir}/Tmp${runday}.txt | sed "s/$/,$Busy/g" >> ${TmpDir}/${runday}Result.txt
let count=count+1
done
rm -rf ${TmpDir}/*${runday}.txt
/usr/local/mysql/bin/mysql -u root -D nagios -pbj7n48dM <<EOF
load data infile '${TmpDir}/${runday}Result.txt' into table t_daily_stats FIELDS TERMINATED BY ',';
EOF本文出自 “nightmare” 博客,谢绝转载!
相关文章推荐
- linux上mysql远程备份和自动导入到指定数据库的shell脚本
- Linux 用 shell 脚本 批量 导入 csv 文件 到 mysql 数据库
- 自动创建数据库并按顺序导入sql文件的shell脚本
- Linux 用 shell 脚本 批量 导入 csv 文件 到 mysql 数据库
- MySql 导入sql脚本 导出sql脚本 数据库
- 通过shell脚本进行数据库操作
- 【笔记】CSV文件导入数据库SQL脚本
- 两个备份数据库的shell脚本
- 用shell脚本操作数据库
- 提取oralce当天的alert log的shell脚本代码
- shell脚本对apache日志分割并统计保存到数据库
- shell 提取mysql指定数据库下表创建语句为单文件
- MAXIMO数据库导入脚本
- C#.NET通用权限管理在DB2数据库上运行的脚本参考 - 通过程序将数据导入到目标数据库中
- shell脚本中导入mysql数据&&执行mysql语句
- 数据库脚本的导入跟导出详解
- [容器]python搭建简易服务器+docker导入多个镜像shell脚本
- shell脚本 日志文件批量导入hive
- 用shell脚本持续监控数据库状态
- 监控数据库锁阻塞_机器连接数_警报日志的shell脚本 分享