• zabbix监控nginx


    检测Nginx模块

    Nginx性能监控需要通过ngx_http_stub_status_module模块来收集指标: 1)检测是否编译ngx_http_stub_status_module模块

    /usr/local/nginx/sbin/nginx -V
    

     如果未启用ngx_http_stub_status_module模块则重新编译Nginx

    Nginx配置文件添加模块配置

    location /ngx_status {  
            stub_status on;         #开启stub_status模块
            allow 127.0.0.1;        #只允许127.0.0.1本地访问
            access_log off;         #不记录日志,如果需要记录日志,删除此行即可
            deny all;               #除了以上允许127.0.0.1以外,拒绝所有地址访问
        }
    

     重启Nginx

    /usr/local/nginx/sbin/nginx -t
    /usr/local/nginx/sbin/nginx -s reload
    

     访问stub_statub模块

    curl http://127.0.0.1/ngx_status
    Active connections: 1
    server accepts handled requests
     16214 16214 8269
    Reading: 0 Writing: 1 Waiting: 0
    

    参数详解: Active connections:Nginx当前活动客户端连接的数量,包括正在等待的连接 accepts:Nginx已经接受客户端的连接总数量 handled:Nginx已经处理客户端的连接总数量 requests:客户端发送的请求的总数量 Reading:Nginx服务器当前正在读取客户端请求头的数量 Writing:Nginx服务器当前正在写响应信息的数量 Waiting:当前有多少客户端在等待Nginx服务器响应

    编写Nginx监控脚本

    编写监控脚本 vim /usr/local/zabbix/scripts/ngx_status.sh

    #!/usr/bin/env bash
    HOST='127.0.0.1'
    PORT='80'
    
    #Nginx进程监控,进程存在值为1,进程停止值为0
    function ping {
            /sbin/pidof nginx | wc -l
    }
    
    #Nginx当前活动客户端连接的数量,包括正在等待的连接
    function active {
            /bin/curl "http://${HOST}:${PORT}/ngx_status" 2>/dev/null | grep 'Active' | awk '{print $NF}'
    }
    
    #Nginx服务器当前正在读取客户端请求头的数量
    function reading {
            /bin/curl "http://${HOST}:${PORT}/ngx_status" 2>/dev/null | grep 'Reading' | awk '{print $2}'
    }
    
    #Nginx服务器当前正在写响应信息的数量
    function writing {
            /bin/curl "http://${HOST}:${PORT}/ngx_status" 2>/dev/null | grep 'Writing' | awk '{print $4}'
    }
    
    #当前有多少客户端在等待服务器响应
    function waiting {
            /bin/curl "http://${HOST}:${PORT}/ngx_status" 2>/dev/null | grep 'Waiting' | awk '{print $6}'
    }
    
    #Nginx已经接受客户端的连接总数量
    function accepts {
            /bin/curl "http://${HOST}:${PORT}/ngx_status" 2>/dev/null | awk NR==3 | awk '{print $1}'
    }
    
    #Nginx已经处理客户端的连接总数量
    function handled {
            /bin/curl "http://${HOST}:${PORT}/ngx_status" 2>/dev/null | awk NR==3 | awk '{print $2}'
    }
    
    #客户端发送的请求的总数量
    function requests {
            /bin/curl "http://${HOST}:${PORT}/ngx_status" 2>/dev/null | awk NR==3 | awk '{print $3}'
    }
    
    $1
    

     修改权限属性

    chown -Rf zabbix.zabbix /usr/local/zabbix/scripts/ngx_status.sh
    chmod u+x /usr/local/zabbix/scripts/ngx_status.sh
    

     Zabbix_GET数据测试

    到zabbix_agentd.conf配置文件中指定Server的主机上进行zabbix_get数据测试

    zabbix_get -s 172.26.3.101 -p 10050 -k "ngx.status[ping]"
    1
    zabbix_get -s 172.26.3.101 -p 10050 -k "ngx.status[active]"
    1
    zabbix_get -s 172.26.3.101 -p 10050 -k "ngx.status[reading]"
    0
    zabbix_get -s 172.26.3.101 -p 10050 -k "ngx.status[writing]"
    1
    zabbix_get -s 172.26.3.101 -p 10050 -k "ngx.status[waiting]"
    0
    zabbix_get -s 172.26.3.101 -p 10050 -k "ngx.status[accepts]"
    16342
    zabbix_get -s 172.26.3.101 -p 10050 -k "ngx.status[handled]"
    16345
    zabbix_get -s 172.26.3.101 -p 10050 -k "ngx.status[requests]"
    8402
    

     编写键值

    编写键值脚本

    vim /usr/local/zabbix/etc/zabbix_agentd.conf.d/userparameter_ngx_status.conf
    UserParameter=ngx.status[*],/usr/local/zabbix/scripts/ngx_status.sh $1
    

     重启Zabbix-Agentd

    /etc/init.d/zabbix_agentd restart
    

     Zabbix_Web创建模板及监控项

    创建模板 主页面点击 配置——》模板——》创建模板

     创建应用集

     创建监控项 进入模板后——》监控项——》创建监控项

     最后创建好如下:

     创建触发器 对进程监控添加触发器,触发器——》创建触发器 填入触发器名称,此名称是告警出的信息——》选择严重性——》添加表达式——》我这里是使用了last函数最新的值如果等于0则触发告警,恢复表达式为last函数最新的至等于1则恢复告警。

     最后创建好如下:又创建了一个当客户端等待Nginx服务器响应数量大于100则告警的触发器

     创建图形 我这里把Nginx性能监控的监控项都放到了图形中,除进程监控外

    主机嵌套模板

    配置——》主机——》进入需要监控Nginx性能的主机——》模板——》添加模板——》选中我们创建的模板

    查看数据

    监测——》最新数据——》选中节点——》选中应用集

     转载:https://mp.weixin.qq.com/s/GyIeUSvbqgEYQNesynghRQ

  • 相关阅读:
    设计模式-状态模式
    设计模式-策略模式
    Spring MVC 梳理
    Spring MVC 梳理
    设计模式-总结
    Spring boot 梳理
    Spring boot 梳理
    [DP题]最长上升子序列
    NOIP2013 Day1
    20171025日程
  • 原文地址:https://www.cnblogs.com/zjz20/p/13294027.html
Copyright © 2020-2023  润新知