设为首页 收藏本站
查看: 552|回复: 0

shell脚本抓取问题进程

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-6-4 08:49:12 | 显示全部楼层 |阅读模式
引用原文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脚本

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
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

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-73700-1-1.html 上篇帖子: 使用PowerShell收集客户端MAC地址 下篇帖子: 使用PowerShell修改Server20102R2系统配置
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表