监控服务-Zabbix自定义脚本监控

一、第一里程:编辑并使用脚本

根据所需监控内容自行编辑脚本内容,并测试成功,例如查看以当前nginx状态信息编辑脚本如下:

[root@web01 ~]# cat /server/scripts/nginx_status.sh 
#!/bin/bash
case "$1" in 
    active)
        curl -s 172.16.1.7/status |awk 'NR==1{print $NF}'
        ;;
    accept)
        curl -s 172.16.1.7/status |awk 'NR==3{print $1}'
        ;;
    handle)
        curl -s 172.16.1.7/status |awk 'NR==3{print $2}'
        ;;
    request)
        curl -s 172.16.1.7/status |awk 'NR==3{print $NF}'
        ;;
    reading)
        curl -s 172.16.1.7/status |awk 'NR==4{print $2}'
        ;;
    writing)
        curl -s 172.16.1.7/status |awk 'NR==4{print $4}'
        ;;
    waiting)
        curl -s 172.16.1.7/status |awk 'NR==4{print $6}'
esac

并测试脚本执行成功

root@web01 ~]# sh /server/scripts/nginx_status.sh active
1
[root@web01 ~]# sh /server/scripts/nginx_status.sh accept
3698
[root@web01 ~]# sh /server/scripts/nginx_status.sh handle
3705
[root@web01 ~]# sh /server/scripts/nginx_status.sh request
3715
[root@web01 ~]# sh /server/scripts/nginx_status.sh reading
0
[root@web01 ~]# sh /server/scripts/nginx_status.sh writing
1
[root@web01 ~]# sh /server/scripts/nginx_status.sh waiting
0

注意:这里一定要测试所有传参都成功,才可以进行下一步
话外篇:在这里我们是以nginx七种状态信息为例子,若使用相同的例子,必须确保nginx服务中开启stub_status;功能,并匹配location,配置如下:

        location /status {
         stub_status;
        }

将此配置放在/etc/nginx/nginx.conf文件下的server模块下即可,nginx.conf文件内容如下:

[root@web01 ~]# cat /etc/nginx/nginx.conf

user  nginx;
worker_processes  1;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;
     server {
        listen       80 default_server;
        server_name  _;
        root         /usr/share/nginx/html;

        location / {
        }
        location /status {
         stub_status;
        }
    }
    include /etc/nginx/conf.d/*.conf;
}

二、第二里程:编辑客户端自定义监控项的配置文件

[root@web01 ~]# cat /etc/zabbix/zabbix_agentd.d/userparameter_status.conf 
UserParameter=nginx.status[*],/bin/sh /server/scripts/nginx_status.sh "$1"

自定义监控脚本的格式与通过命令自定义监控的格式一致,只不过在给自定义监控项设置名称时需要在后面添加对应的变量,在这里通常都是用*号代表所有变量,并用中括号括起,逗号后面接上对应的执行脚本命令,注意一定要写脚本的绝对路径,后面跟上传参,有一个就一个,有俩个就写俩个,分别用“”引起。

三、第三里程:重启客户端

systemctl restart zabbix-agent.service

四、第四里程:服务端检测是否正常接收客户端数据信息

[root@zabbix ~]# zabbix_get -s 172.16.1.7 -k nginx.status[active]
1

注意:在配置自定义监控脚本时,[*]中的中括号里面的*号,代表脚本所需的所有传参,因此在客户端发送及获取数据时,不能以*号代替所有传参,必须一个一个变量填写,如上图所示

五、web页面配置

  • 第一步:在配置中找到对应的模板,给该脚本监控项设置应用集。


    找到对应模板

    创建应用集

    应用集命名并添加
  • 第二步:创建监控项,注意这里创建监控项时一定要根据监控项的变量个数,来决定写多少个监控项,例如监控nginx的状态信息,一共在脚本中设定了7个变量,那么就需要添加7个监控项,不可用*号代替。
    创建监控项

    创建监控项内容,其余默认即可

    PS:创建多个类似相同的监控项,可以点击选中的监控项,进入后点击最下方的克隆即可
  • 第三步:创建触发器,根据实际情况决定,是否需要报警,如不需要可不设置,例如当nginx等待响应数据大于10时,发出一般严重报警,可按以下配置。
    创建监控项

    添加监控项

    添加监控项及内容详解请见:https://www.jianshu.com/p/ec86683cc9a9
    最终显示结果
  • 第四步:创建图形,用来直观感受收集的数据信息


    创建图形

    添加图形

    这里需要注意的就是将需要图形化展示的监控项逐一添加到监控项选项中。


    显示图像
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容