zabbix iostat 监控模板安装与配置


  1. 配置定时任务,用于生成iostat的统计数据

    crontab -e

    * * * * * /usr/local/zabbix327/bin/iostat-cron.sh

  2. 编辑 /usr/local/zabbix327/bin/iostat-cron.sh


    #!/bin/bash DEST_DATA=/tmp/iostat-data
    TMP_DATA=/tmp/iostat-data.tmp iostat -kx 10 2 > $TMP_DATA
    mv $TMP_DATA $DEST_DATA
  3. 添加执行权限

    # chmod +x iostat-cron.sh

  4. 编辑 /usr/local/zabbix327/bin/lld-iostat.sh

    #!/bin/bash
    
    DEVICES=`iostat | awk '{ if ($1 ~ "^([shxv]|xv)d[a-z]$") { print $1 } }'`
    
    COUNT=`echo "$DEVICES" | wc -l`
    INDEX=0
    echo '{"data":['
    echo "$DEVICES" | while read LINE; do
    echo -n '{"{#DEVNAME}":"'$LINE'"}'
    INDEX=`expr $INDEX + 1`
    if [ $INDEX -lt $COUNT ]; then
    echo ','
    fi
    done
    echo ']}'
  5. 添加执行权限

    # chmod +x lld-iostat.sh

  6. 编辑 /usr/local/zabbix327/bin/iostat.sh

    #!/bin/bash
    
    ZBX_REQ_DATA="$2"
    ZBX_REQ_DATA_DEV="$1" SOURCE_DATA=/tmp/iostat-data ERROR_NO_DATA_FILE="-0.9900"
    ERROR_OLD_DATA="-0.9901"
    ERROR_WRONG_PARAM="-0.9902"
    ERROR_MISSING_PARAM="-0.9903" if [ ! -f "$SOURCE_DATA" ]; then
    echo $ERROR_NO_DATA_FILE
    exit 1
    fi if [ -z "$ZBX_REQ_DATA_DEV" ]; then
    echo $ERROR_MISSING_PARAM
    exit 1
    fi OLD_DATA=5
    if [ $(stat -c "%Y" $SOURCE_DATA) -lt $(date -d "now -$OLD_DATA min" "+%s" ) ]; then
    echo $ERROR_OLD_DATA
    exit 1
    fi
    device_count=$(grep -Ec "^$ZBX_REQ_DATA_DEV " $SOURCE_DATA)
    if [ $device_count -eq 0 ]; then
    echo $ERROR_WRONG_PARAM
    exit 1
    fi case $ZBX_REQ_DATA in
    rrqm/s) grep -E "^$ZBX_REQ_DATA_DEV " $SOURCE_DATA | tail -1 | awk '{print $2}';;
    wrqm/s) grep -E "^$ZBX_REQ_DATA_DEV " $SOURCE_DATA | tail -1 | awk '{print $3}';;
    r/s) grep -E "^$ZBX_REQ_DATA_DEV " $SOURCE_DATA | tail -1 | awk '{print $4}';;
    w/s) grep -E "^$ZBX_REQ_DATA_DEV " $SOURCE_DATA | tail -1 | awk '{print $5}';;
    rkB/s) grep -E "^$ZBX_REQ_DATA_DEV " $SOURCE_DATA | tail -1 | awk '{print $6}';;
    wkB/s) grep -E "^$ZBX_REQ_DATA_DEV " $SOURCE_DATA | tail -1 | awk '{print $7}';;
    avgrq-sz) grep -E "^$ZBX_REQ_DATA_DEV " $SOURCE_DATA | tail -1 | awk '{print $8}';;
    avgqu-sz) grep -E "^$ZBX_REQ_DATA_DEV " $SOURCE_DATA | tail -1 | awk '{print $9}';;
    await) grep -E "^$ZBX_REQ_DATA_DEV " $SOURCE_DATA | tail -1 | awk '{print $10}';;
    svctm) grep -E "^$ZBX_REQ_DATA_DEV " $SOURCE_DATA | tail -1 | awk '{print $11}';;
    %util) grep -E "^$ZBX_REQ_DATA_DEV " $SOURCE_DATA | tail -1 | awk '{print $12}';;
    *) echo $ERROR_WRONG_PARAM; exit 1;;
    esac exit 0
  7. 添加执行权限

    # chmod +x iostat.sh

  8. 测试

    • 检查/tmp/下的文件:iostat-data、iostat-data.tmp 是否生成

    • 测试脚本在zabbix用户下是否执行正确:

      $ ./lld-iostat.sh

      $ ./iostat.sh hda w/s

  9. 编辑zabbix agentd 配置文件并增加自定义参数,包括 lld 参数以及监控参数

    UserParameter=custom.vfs.dev.discovery,/usr/local/zabbix327/bin/lld-iostat.sh

    UserParameter=iostat[*],/usr/local/zabbix327/bin/iostat.sh $1 $2

  10. 重启 zabbix_agentd

  11. 配置模板/导入模板

    1. Configuration/Templates, 点击Create template , 输入模板名称,并选择Groups,并保存

    2. 选择 Discovery rules,点击 Create discovery rule,填写必要信息后,进行保存

      • Name :Disk Devices
      • Key : custom.vfs.dev.discovery
      • Update interval: 60
    3. 选择 Discovery rules,并点击列表中的 Item prototypes , 点击 Create item prototype 按钮,配置完成后进行保存。

      • Name: $1 $2 /****** $1 表示Key的第一个参数 $2 表示Key的第二个参数 ***/
      • Key : iostat[{#DEVNAME},svctm]
      • Type of information: Numberic (float)
      • Applications: iostat
    4. 按以上方法依次配置以下Item prototype(只需修改Key的第二个参数):

      %util,rkB/s,avgqu-sz,await,wkB/s, w/s,avgrq-sz, rrqm/s, wrqm/s,r/s

  12. 根据需要配置Trigger prototypes

    选择Trigger prototypes tab,并点击Create trigger prototype,这里重点说明,Expression部分,

    点击 Add 按钮,在弹出的窗口,点击 Select prototype,选择监控项,然后配置其他项目。最后点击保存。

最新文章

  1. python中的变量和数据类型
  2. Apache Spark技术实战之2 -- PackratParsers实例
  3. 查看 MySQL 数据库中每个表占用的空间大小
  4. C语言里的指针探析——type *name[] 在函数参数里面,是一个二维指针
  5. yii2源码学习笔记(十五)
  6. Cable master(好题,二分)
  7. Linux学习awk命令
  8. Codeforces 437A The Child and Homework
  9. ECOS-Mongodb安装
  10. memcache数据组织
  11. 实体处理模块IEntityModule
  12. mysql下优化表和修复表命令使用说明(REPAIR TABLE和OPTIMIZE TABLE)
  13. 3.JAVA基础复习——JAVA中的类与对象
  14. SQLServer索引及统计信息
  15. 将window的shell脚本通过ftp传输到Linux服务器后, shell脚本中执行时提示“没有那个文件或目录”的解决办法
  16. POJ 3415 Common Substrings 【长度不小于 K 的公共子串的个数】
  17. C# 文件过滤器filter
  18. PL/SQL编程基础(三):数据类型划分
  19. shell 切分文件名提取文件扩展名或提取文件名
  20. Helm Charts

热门文章

  1. ZOJ 4010 Neighboring Characters(ZOJ Monthly, March 2018 Problem G,字符串匹配)
  2. URL的组成
  3. github安装k8s
  4. [BZOJ4850][JSOI2016]灯塔(分块/决策单调性优化DP)
  5. UOJ 310 黎明前的巧克力(FWT)
  6. [POI2015]Myjnie
  7. Codeforces Round #354 (Div. 2) A. Nicholas and Permutation 水题
  8. [Visual Studio] 重置默认设置 还原默认设置
  9. 读书笔记_Effective_C++_条款三十四:区分接口继承和实现继承
  10. ROS知识(6)----卸载ROS系统