码迷,mamicode.com
首页 > 系统相关 > 详细

shell脚本抓取问题进程

时间:2015-06-03 19:49:22      阅读:279      评论:0      收藏:0      [点我收藏+]

标签:监控 shell 进程 load cpu

引用原文shell脚本:
#/bin/bash
LOAD=$(awk ‘{print $1}‘ /proc/loadavg)
CPUNUM=$(grep -c processor /proc/cpuinfo)

if [ $(echo "$LOAD > $CPUNUM" | bc) = 1 ]; then
    RESULT=$(ps -eo pcpu,pmem,user,args | awk ‘$1 > 0‘ | sort -nr)
    if [ -n "$RESULT" ]; then
        echo "$RESULT" > /var/log/ps.$(date +"%Y%m%d%H%M")
    fi
fi

shell脚本抓取问题进程
晚上某个时段收到某台服务器load很高,但再登录服务器查看时候load可能已经下降了,
所以使用shell脚本来处理解决问题 监控频率30秒1次 将系统负载超过一定数值就记录到文本里,
我这边修改了原文shell脚本

cat load.sh 
#!/bin/bash
#--------------------------------------------------
#Author:jimmygong
#Email:jimmygong@taomee.com
#FileName:load.sh
#Function: 
#Version:1.0 
#Created:2015-06-02
#--------------------------------------------------
sleeptime=30
logpath="/opt/scripts"
[[ -d $logpath ]] || mkdir $logpath
echosucc () 
{
    succstatus="[ Ok ]"
    printf "\033[32m $succstatus $* \033[0m\n"
}
function usage ()
{
    echo "Usage: $0 {start|stop}"
}
if [[ $# -ne 1 ]]
then
    usage
    exit 1
fi
function start () 
{
    echosucc "Starting load monitor"
    while true
    do
        load=$(cat /proc/loadavg|awk ‘{print $1}‘)
        cpunum=$(cat /proc/cpuinfo|grep -c processor)
        if [[ $(echo "$load > $cpunum" | bc) = 1 ]]
        then
            result=$(ps -eo pcpu,pmem,user,args|awk ‘$1 > 0‘ |sort -nr)
            if [[ -n "$result" ]]
            then
                echo "$result" > $logpath/load.$(date +"%Y%m%d%H%M")
            fi
        fi
        sleep $sleeptime
    done
}
function stop () 
{
    echo $$ > "$logpath/pidfile"
    for PID in $(ps -eo pid,command|grep "$0"|grep -v grep|awk ‘{print $1}‘);
    do
        [[ $PID != $(cat $logpath/pidfile) ]] && kill -s TERM $PID >& /dev/null
    done
    echosucc ‘Stopping load monitor‘
}
case $1 in
    start)
    start &
    ;;
    stop)
    stop
    ;;
    *)
    usage
    ;;
esac

==========================参数说明==============================
man ps 可以看到下面说明
CODE   NORMAL   HEADER
%C     pcpu     %CPU
%G     group    GROUP
%P     ppid     PPID
%U     user     USER
%a     args     COMMAND
%c     comm     COMMAND
%g     rgroup   RGROUP
%n     nice     NI
%p     pid      PID
%r     pgid     PGID
%t     etime    ELAPSED
%u     ruser    RUSER
%x     time     TIME
%y     tty      TTY
%z     vsz      VSZ

本文出自 “7928217” 博客,请务必保留此出处http://7938217.blog.51cto.com/7928217/1657964

shell脚本抓取问题进程

标签:监控 shell 进程 load cpu

原文地址:http://7938217.blog.51cto.com/7928217/1657964

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!