zabbix 自动发现 占用io最多的前十进程

简介:

因为过程中碰到sudo -u zabbix pidstat -d 无法显示信息,所以无法获取数据。

换了一种方法

  1. 生成临时文件

cat pidsta.sh

#!/bin/bash

while [ true ]; do

/bin/sleep 2

pidstat -d|awk 'NR>3'|awk '{print $4,$6}'|awk '{a[$2]+=$1} END{for(i in a) print a[i],i}'|sort -nr -k 1|head -n 10  >/tmp/pidsta

done

nohup sh pidsta.sh &

2.获取进程名

cat pidtest.sh

#!/bin/bash

#Fucation:mysql low-level discovery

#Script_name mysql_low_discovery.sh

pidtest() {

            port=($(cat /tmp/pidsta|awk '{print $2}'))

            printf '{\n'

            printf '\t"data":[\n'

               for key in ${!port[@]}

                   do

                       if [[ "${#port[@]}" -gt 1 && "${key}" -ne "$((${#port[@]}-1))" ]];then

                          printf '\t {\n'

                          printf "\t\t\t\"{#PIDSTA}\":\"${port[${key}]}\"},\n"

                     else [[ "${key}" -eq "((${#port[@]}-1))" ]]

                          printf '\t {\n'

                          printf "\t\t\t\"{#PIDSTA}\":\"${port[${key}]}\"}\n"

                       fi

               done

                          printf '\t ]\n'

                          printf '}\n'

}

$1

3.获取对应的数值

cat pidnum.sh

#!/bin/bash

cat /tmp/pidsta|grep -w $1|awk '{print $1}'

4.cat pidtest.conf

UserParameter=pidtest.discovery[*],/bin/bash /usr/local/zabbix/bin/pidtest.sh $1

UserParameter=pidtest.num[*],/bin/bash /usr/local/zabbix/bin/pidnum.sh $1

5.创建模板就略过了。

做这个的原因是有一台从mysql,到某个时刻io就升高,持续几分钟就恢复正常,想找出这几分钟io高的进程,来判断原因




本文转自 liqius 51CTO博客,原文链接:http://blog.51cto.com/szgb17/1889532,如需转载请自行联系原作者

相关文章
|
2月前
|
程序员 调度 云计算
Python并发编程的未来趋势:协程、异步IO与多进程的融合
Python并发编程的未来趋势:协程、异步IO与多进程的融合
|
2月前
|
网络协议 Linux
【系统DFX】如何诊断占用过多 CPU、内存、IO 等的神秘进程?
【系统DFX】如何诊断占用过多 CPU、内存、IO 等的神秘进程?
106 0
|
11月前
|
Java
【Java筑基】IO流基础之常见工具流和进程通信
【Java筑基】IO流基础之常见工具流和进程通信
|
Linux Shell
Linux 温习(九): IO 重定向与进程管道
I/O输入/输出(Input/Output)的简称,I 即为输入,常见的输入设备有键盘和鼠标。O为输出,常见的打印机等。
120 0
|
Java 数据库 芯片
物无定味适口者珍,Python3并发场景(CPU密集/IO密集)任务的并发方式的场景抉择(多线程threading/多进程multiprocessing/协程asyncio)
一般情况下,大家对Python原生的并发/并行工作方式:进程、线程和协程的关系与区别都能讲清楚。甚至具体的对象名称、内置方法都可以如数家珍,这显然是极好的,但我们其实都忽略了一个问题,就是具体应用场景,三者的使用目的是一样的,换句话说,使用结果是一样的,都可以提高程序运行的效率,但到底那种场景用那种方式更好一点?
物无定味适口者珍,Python3并发场景(CPU密集/IO密集)任务的并发方式的场景抉择(多线程threading/多进程multiprocessing/协程asyncio)
|
监控 Linux
【zabbix教程四】——zabbix3.0监控磁盘IO与自定义模板
【zabbix教程四】——zabbix3.0监控磁盘IO与自定义模板
327 0
【zabbix教程四】——zabbix3.0监控磁盘IO与自定义模板
|
关系型数据库 MySQL Linux
Linux 查看磁盘 查看磁盘IO并找出占用 并找出占用IO读写很高的进程
Linux 查看磁盘 查看磁盘IO并找出占用 并找出占用IO读写很高的进程
411 0
Linux 查看磁盘 查看磁盘IO并找出占用 并找出占用IO读写很高的进程
|
Java 数据库 芯片
物无定味适口者珍,Python3并发场景(CPU密集/IO密集)任务的并发方式的场景抉择(多线程threading/多进程multiprocessing/协程asyncio)
一般情况下,大家对Python原生的并发/并行工作方式:进程、线程和协程的关系与区别都能讲清楚。甚至具体的对象名称、内置方法都可以如数家珍,这显然是极好的,但我们其实都忽略了一个问题,就是具体应用场景,三者的使用目的是一样的,话句话说,使用结果是一样的,都可以提高程序运行的效率,但到底那种场景用那种方式更好一点? 这就好比,目前主流的汽车发动机变速箱无外乎三种:双离合、CVT以及传统AT。主机厂把它们搭载到不同的发动机和车型上,它们都是变速箱,都可以将发动机产生的动力作用到车轮上,但不同使用场景下到底该选择那种变速箱?这显然也是一个问题。
|
监控 机器学习/深度学习 Windows

热门文章

最新文章

推荐镜像

更多