zabbix监控Nginx

目录

一、环境准备

二、部署Nginx被监控端

三、自定义Nginx监控key

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


一、环境准备

搭建zabbix基础环境

zabbix基础环境部署参照:部署Zabbix监控

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

二、部署Nginx被监控端

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

Nginx下载地址:部署Zabbix监控

#在web1主机安装
yum install gcc pcre-devel openssl-devel -ytar -xvf nginx-1.22.1.tar.gzcd nginx-1.22.1./configure --with-http_stub_status_modulemake && 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;
        }

        ... ...

}

#启动nginx
/usr/local/nginx/sbin/nginx

验证nginx状态页面:

curl http://192.168.2.20/status

 

三、自定义Nginx监控key

语法格式:

UserParameter=key,command

UserParameter=key[*],<command>

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

添加如下内容:

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

重启agent:

killall zabbix_agentdzabbix_agentd

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

vim /usr/local/bin/nginx_status.sh#!/bin/bash
case $1 in
active)curl -s http://127.0.0.1/status | awk '/Active/{print $NF}';;
waiting)curl -s http://127.0.0.1/status | awk '/Waiting/{print $NF}';;
accepts)curl -s http://127.0.0.1/status | awk 'NR==3{print $2}';;
esacchmod +x /usr/local/bin/nginx_status.sh#测试zabbix_get能否获取
zabbix_get -s 127.0.0.1 -k 'nginx.status[accepts]'
zabbix_get -s 127.0.0.1 -k 'nginx.status[waiting]'
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主机并发数变化:

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

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

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/69834.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HCIP学习--BGP实验

一、实验拓扑 二、实验需求 除R5的5.5.5.0环回外&#xff0c;其他所有的环回均可互相访问 三、实验步骤 首先配置IP&#xff0c;配置好IBGP 建立直连的EBGP邻居关系 R1和R2建立直连的EBGP邻居关系 [r1]bgp 1 [r1-bgp]router-id 1.1.1.1 [r1-bgp]peer 12.1.1.2 as-number …

剑指offer-2.2字符串

字符串 C/C中每个字符串都以字符"\0"作为结尾&#xff0c;这样我们就能很方便地找到字符串的最后尾部。但由于这个特点&#xff0c;每个字符串中都有一个额外字符的开销&#xff0c;稍不留神就会造成字符串的越界。比如下面的代码&#xff1a; char str [10]; strc…

编程练习(1)

目录 一.选择题 第一题&#xff1a; 第二题&#xff1a; 第三题&#xff1a; 第四题&#xff1a; 第五题&#xff1a; ​编辑 二.编程题 第一题&#xff1a; 第二题&#xff1a; 1.暴力方法&#xff1a; 2.数组法&#xff1a; 一.选择题 第一题&#xff1a; 解析&…

已知四个坐标点,怎样求出四边形的四个内角

1&#xff0c;理论 最简单的方式利用向量进行求解 如图可得&#xff1a; cosθa*b/&#xff08;|a|*|b|&#xff09; 已知三点坐标&#xff0c;很容易可以得到两向量之积a*b&#xff0c;以及每个的模值 2&#xff0c;四个角度求解过程 首先&#xff0c;我们定义了四个坐标点…

微服务学习笔记-基本概念

微服务是一种经过良好架构设计的分布式架构方案。根据业务功能对系统做拆分&#xff0c;每个业务功能模块作为独立项目开发&#xff0c;称为一个服务。 微服务的架构特征&#xff1a; 单一职责&#xff1a;微服务拆分粒度更小&#xff0c;每一个服务都对应唯一的业务能力&…

Vivado使用入门之二:网表物理约束

目录 一、背景 二、物理约束 2.1 概念 2.2 网表约束 2.2.1 CLOCK_DEDICATED_ROUTE 2.2.2 MARK_DEBUG 2.2.3 DONT_TOUCH 2.2.4 LOCK_PINS 三、位置约束 四、布线约束 4.1 route 4.2 assign routing mode 五、参考 一、背景 在工程设计中为了保证上板后功能正常&…

RabbitMQ工作流程详解

1 生产者发送消息的流程 (1)生产者连接RabbitMQ&#xff0c;建立TCP连接(Connection)&#xff0c;开启信道(Channel) (2)生产者声明一个Exchange (交换器)&#xff0c;并设置相关属性&#xff0c;比如交换器类型、是否持久化等 (3)生产者声明一个队列井设置相关属性&#xf…

eachars 自适应

目录 1. 案例&#xff1a; 2. 原因&#xff1a; 3. 解决&#xff1a; 1. 案例&#xff1a; 默认是正常宽度&#xff08;如图1&#xff09;&#xff0c;当再次跳转会该页面时&#xff0c;eachars图发生变化&#xff08;如图2&#xff09;。 图1 图2 2. 原因&#xff1a; 没有…

Gitlab-第四天-CD到k8s集群的坑

一、.gitlab-ci.yml #CD到k8s集群的 stages: - deploy-test build-image-deploy-test: stage: deploy-test image: bitnami/kubectl:latest # 使用一个包含 kubectl 工具的镜像 tags: - k8s script: - ls -al - kubectl apply -f deployment.yaml # 根据实际情况替换…

Redis持久化——RDB和AOF

Redis数据库是内存数据库&#xff0c;一旦出现服务宕机&#xff0c;那么内存中的数据就容易丢失。所以需要进行redis的持久化动作。 Redis持久化是指将Redis内存数据持存储到磁盘中&#xff0c;若出现了Redis服务宕机后&#xff0c;能够从硬盘中再恢复到Redis内存中。 Redis的持…

公司电脑三维图纸加密、机械图挡加密软件

机械图纸加密软件的问世&#xff0c;让很多的网络公司都大受其带来的工作中的便利。在安装了机械图纸加密软件后&#xff0c;不仅可以很好的管理员工在工作时的上网娱乐&#xff0c;在对整个公司员工的工作效率上也有着明显的提高&#xff0c;那么对于机械图纸加密软件的具体特…

Docker一键部署项目,无需登录XShell

文章目录 一键部署项目Docker手动部署SpringBoot项目编写docker部署的脚本文件script.sh 脚本内容 特别注意&#xff01;编写dockerfiledockerfile 文件内容 上传后端服务的jar包到服务器中执行 script 脚本部署后端服务 自动部署SpringBoot项目引入jsch依赖编写jsch工具类执行…