• zabbix监控Nginx


    目录

    一、环境准备

    二、部署Nginx被监控端

    三、自定义Nginx监控key

    四、给目标主机创建监控项


    一、环境准备

    搭建zabbix基础环境

    zabbix基础环境部署参照:zabbix基础环境部署_桂安俊@kylinOS的博客-CSDN博客

    以下实验部署均基于上述环境

    二、部署Nginx被监控端

    此处选择在web1搭建Nginx服务,部署Nginx时要加载status模块

    Nginx下载地址:nginx: download

    1. #在web1主机安装
    2. yum install gcc pcre-devel openssl-devel -y
    3. tar -xvf nginx-1.22.1.tar.gz
    4. cd nginx-1.22.1
    5. ./configure --with-http_stub_status_module
    6. make && make install

    修改Nginx配置

    vim /usr/local/nginx/conf/nginx.conf

    在server块里面新增一个location块,用户显示状态,新增内容如下红色标记部分:

    ... ...

    server {
            listen       80;
            server_name  localhost;

            #charset koi8-r;

            #access_log  logs/host.access.log  main;

            location / {
                root   html;
                index  index.html index.htm;
            }

            location /status {
                stub_status on;
            }
      
            #error_page  404              /404.html;
            
            # redirect server error pages to the static page /50x.html
            #
            error_page   500 502 503 504  /50x.html;
            location = /50x.html {
                root   html;
            }

            ... ...

    }

    1. #启动nginx
    2. /usr/local/nginx/sbin/nginx

    验证nginx状态页面:

    curl http://192.168.2.20/status

     

    三、自定义Nginx监控key

    语法格式:

    UserParameter=key,command

    UserParameter=key[*],

    key里的所有参数,都会传递给后面命令的位置变量

    举例:

    UserParameter=ping[*],echo $1

    ping[0]                 #返回的结果都是0

    ping[aaa]             #返回的结果都是aaa

    在被监控端web1主机创建监控key文件:

    (注意创建自定义监控key要在agent端/usr/local/etc/zabbix_agentd.conf里设置Include,前文环境已经设置过,这里不再重复)

    vim /usr/local/etc/zabbix_agentd.conf.d/nginx.status

    添加如下内容:

    1. #将nginx.status[]里的参数,传递给后面sh脚本的位置参数里
    2. UserParameter=nginx.status[*],/usr/local/bin/nginx_status.sh $1

    重启agent:

    1. killall zabbix_agentd
    2. zabbix_agentd

    以上创建好监控key,但是nginx_status.sh脚本还不存在,下面编写脚本:

    vim /usr/local/bin/nginx_status.sh

    脚本内容如下:

    1. #!/bin/bash
    2. case $1 in
    3. active)
    4. curl -s http://127.0.0.1/status | awk '/Active/{print $NF}';;
    5. waiting)
    6. curl -s http://127.0.0.1/status | awk '/Waiting/{print $NF}';;
    7. accepts)
    8. curl -s http://127.0.0.1/status | awk 'NR==3{print $2}';;
    9. esac
    1. chmod +x /usr/local/bin/nginx_status.sh
    2. #测试zabbix_get能否获取
    3. zabbix_get -s 127.0.0.1 -k 'nginx.status[accepts]'
    4. zabbix_get -s 127.0.0.1 -k 'nginx.status[waiting]'
    5. zabbix_get -s 127.0.0.1 -k 'nginx.status[accepts]'

     

    四、给目标主机创建监控项

            这里可以先创建监控模板,把监控项添加到监控模板,也可以直接找到目标主机,把目标主机添加该监控项,区别是通过监控模板,后面可以给其他主机用,如果是直接到目标主机添加监控项,那这个监控项后面不能给其他主机直接用,除非别的主机也去创建监控项。这里为了测试方便,就直接给目标主机添加items监控项:

    Configuration--->Hosts--->选择目标主机web1后面的items,点击后面的Create item:

     如下图,设置自定义监控项名称,键值手动输入,nginx.status[accepts],括号里面是手动传入的参数,设置完成后选择最下面的添加:

    回到web1主机的监控项列表里面,可以看到多了一个监控项nginx_status:

     点击监测中--->最新数据--->选择web1主机,找到nginx_status监控项,可以看到监控数值:

     也可以点击后面的图形,查看折线图:

     我们可以在zabbixserver主机使用ab命令,模拟向web1 nginx服务器发送并发数据,观察web1主机并发数变化:

    1. #在zabbixserver主机执行,任何非web1主机都可以,发送并发数访问
    2. ab -c 100 -n 10000 http://192.168.2.20/

    再次查看web1的监控数据,发现并发数有明显变化:

     

  • 相关阅读:
    Glide源码解析二---into方法
    docker高级网络配置、高级数据卷机制和Dockerfile说明
    Go语言面试题合集(2022)
    「分布式」——微服务抽奖系统后台整合MyBatis-Plus
    出现 Transaction rolled back because it has been marked as rollback-only 解决方法
    Maven CheckStyle Plugin集成
    中国青年报APP设备注册
    SMOTE与SMOGN算法R语言代码
    使用containerd从0搭建k8s(kubernetes)集群
    小菜学前端笔记-06-03
  • 原文地址:https://blog.csdn.net/qq_28903377/article/details/128104967