• 6、zabbix使用进阶(02)


    zabbix知识点:

    zabbix可视化

    自定义图形(graphs)

    屏幕(screen)

    宏(macros) 

    用户参数(User parameters):用户自定义items key的方式来实现自定义监控数据指标

    zabbix模板

    zabbix可视化

    zabbix提供了graph、screen和map等可视化工具

    Graph介绍

    Screen

    由于screen可以展示多个主机上的图,所以screen的定义不是以host为中心定义的

    宏(Macros)   https://www.zabbix.com/documentation/3.4/manual/appendix/macros/supported_by_location

    宏有两类:  http://blog.51cto.com/afterdawn/1924147

    内置{MACRO_NAME}    不需要加$就可以引用:

    zabbix有许多内置的宏,如{HOST.NAME}、{HOST.IP}、{TRIGGER.DESCRIPTION}、{TRIGGER.NAME}、{TRIGGER.EVENTS.ACK}等。

    自定义{$MACRO_NAME}  需要加$才能引用:

    注意:在调用和定义时都需要加$

    为了更强的灵活性,zabbix还支持在全局、模板或主机级别使用用户自定义宏(user macro)

    用户自定义宏使用"{$MACRO}"这种特殊的语法格式

    宏可以应用在item keys和descriptions、trigger名称和表达式、主机接口IP/DNS及端口、discovery机制的SNMP协议的相关信息中等。

    宏的级别:

    全局:定义全局宏,全局定义

    模板:定义模板宏,在模板上定义

    主机:定义主机宏,在主机上定义

    宏的替换次序

    主机-->模板-->全局(查找顺序,优先级顺序:主机-->模板-->全局)

    先在主机上查找,如果主机没有定义,然后在模板上查找,如果仍然没有定义,在全局查找

     

    定义全局宏,在每一个主机上都可以用

    定义主机宏

    找到Monitoring --> Lastest data --> Graph(node2行)可以看到下图的值就为1000了,因为主机级别的宏级别最高

    创建模板Templates(所有模板被链接以后才能被定义)

     

    模板:一系列配置的集合,此些配置可通过"链接"的方式应用于指定的主机

    模板包括:Applications、Items、Triggers、Graphs、Screens、Discovery、Web

    模板可以嵌套,可以从其他模板的基础上继承此前的配置,然后再对此配置做修改

     

    指定维护时间

     

    User Parameters:  https://www.zabbix.com/documentation/4.0/zh/manual/config/items/userparameters

    zabbix 内置了许多item key

    意义:实现用户自定义item key,实现特有数据指标监控

    一条用户自定义参数配置应当使用以下语法:

    UserParameter=<key>,<command>

    示例解析:

    UserParameter=Nginx.active[*], /usr/bin/curl -s "http://$1:$2/status" | awk '/^Active/ {print $NF}'   

    //Nginx.active[*]代表key,[*]表示可以接受任何数量的参数;"http://$1:$2/status"中$1和$2就是key上传递的参数

    下面是没有key的调用示例:

    在agent端定义:

    # vim /etc/zabbix/zabbix_agentd.conf  

    Include=/etc/zabbix/zabbix_agentd.d/*.conf      //这个目录下所有以.conf结尾的文件都可以被读进来

    # Include=/usr/local/etc/zabbix_agentd.userparams.conf
    # Include=/usr/local/etc/zabbix_agentd.conf.d/
    # Include=/usr/local/etc/zabbix_agentd.conf.d/*.conf

    # vim /etc/zabbix/zabbix_agentd.d/os.conf   

    UserParameter=os.memory.used,free -m | awk '/^Mem/ {print $3}'

    # systemctl restart zabbix-agent

    # vim /etc/zabbix/zabbix_agentd.d/os.conf   //定义多个字段

    UserParameter=os.memory.used,free -m | awk '/^Mem/ {print $3}'
    UserParameter=os.memory.free,free -m | awk '/^Mem/ {print $4}'
    UserParameter=os.memory.total,free -m | awk '/^Mem/ {print $2}' 

    # systemctl restart zabbix-agent

    nginx status 开启方法:
    server {
        ...
        location /status {
            stub_status on;
            access_log off;
            allow 123.123.123.123; # 允许访问的 IP
            allow 127.0.0.1;
            deny all;
        }
    }
    
    状态页面各项数据的意义:
    active connections – 当前 Nginx 正处理的活动连接数。
    serveraccepts handled requests — 总共处理了 233851 个连接 , 成功创建 233851 次握手 (证明中间没有失败的 ), 总共处理了 687942 个请求 ( 平均每次握手处理了 2.94 个数据请求 )。
    reading — nginx 读取到客户端的 Header 信息数。
    writing — nginx 返回给客户端的 Header 信息数。
    waiting — 开启 keep-alive 的情况下,这个值等于 active – (reading + writing), 意思就是 Nginx 已经处理完正在等候下一次请求指令的驻留连接。

    可扩展用户参数:

    UserParameter=key[*],command  //定义UserParameter时可以接受参数,[*]表示可以接受任意数量的参数,在command中可以调用[*]任意传递过来的参数,

                                  //即用户在zabbix server上定义key时,传递过来的参数直接可以被command调用。$0表示命令本身

    UserParameter=Nginx.active[*], /usr/bin/curl -s "http://$1:$2/status" | awk '/^Active/ {print $NF}'       //Nginx.active[*]是key,/usr/bin/curl -s "http://$1:$2/status" | awk '/^Active/ {print $NF}'是command
    UserParameter=Nginx.reading[*], /usr/bin/curl -s "http://$1:$2/status" | grep 'Reading' | cut -d" " -f2   //key可以接受参数,参数的作用是什么呢?使用curl命令,以静态模式(-s)获取这个服务器(http://$1:$2/status)上的status这个URL,
    UserParameter=Nginx.writing[*], /usr/bin/curl -s "http://$1:$2/status" | grep 'Writing' | cut -d" " -f4   //$1代表服务器地址,$2代表端口号,$1和$2都是来自[*]。取到以后找到active所在的行,并打印最后一个字段
    UserParameter=Nginx.waiting[*], /usr/bin/curl -s "http://$1:$2/status" | grep 'Waiting' | cut -d" " -f6
    UserParameter=Nginx.accepted[*], /usr/bin/curl -s "http://$1:$2/status" | awk '/^[ ]+[0-9]+[ ]+[0-9]+[ ]+[0-9]+/ {print $$1}'
    UserParameter=Nginx.handled[*], /usr/bin/curl -s "http://$1:$2/status" | awk '/^[ ]+[0-9]+[ ]+[0-9]+[ ]+[0-9]+/ {print $$2}'
    UserParameter=Nginx.requests[*], /usr/bin/curl -s "http://$1:$2/status" | awk '/^[ ]+[0-9]+[ ]+[0-9]+[ ]+[0-9]+/ {print $$3}'

    另外用一个命令来监控数据库查询、删除、更新等各个操作的次数有多少个?(注意:是server端获取agent端的mysql数据信息)

    # mysql -e "SHOW GLOBAL STATUS"  //首先可以查看所有全局变量

    # mysql -e "SHOW GLOBAL STATUS" | awk '/Com_select/{print $0}'   //取出单个全局变量的数值

    Com_select 302225

    # mysql -e "SHOW GLOBAL STATUS" | awk '/Com_select/{print $2}'
       302583

    UserParameter=Mysql.dml[*], /usr/bin/mysql -h$1 -u$2 -p$3 -e 'SHOW GLOBAL STATUS' | awk "/Com_$4>/{print $$2}"

    //$1代表数据库用户名,$2代表主机IP,$3代表登陆密码,$4代表 * 传递过来的命令本身(select、delete),$$2表示取出的全局变量的数值

    测试一下

    # cmd='select'
    # /usr/bin/mysql -e 'SHOW GLOBAL STATUS' | awk "/Com_$cmd>/{print $$2}"
      140282

    # /usr/bin/mysql -uzbxuser -h192.168.128.131 -p123456 -e 'SHOW GLOBAL STATUS' | awk "/Com_$cmd>/{print $$2}"
       140282

    示例测试:(注意是在agent端)

    # vim /etc/zabbix/zabbix_agentd.d/mysql.conf

    UserParameter=Mysql.dml[*], /usr/bin/mysql -h$1 -u$2 -p$3 -e 'SHOW GLOBAL STATUS' | awk "/Com_$4>/{print $$2}"

    # systemctl restart zabbix-agent

    # yum install mariadb-server

    在server端进行测试,是否能取到mysql中的数值,注意是zabbix server端

    # zabbix_get -s 192.168.128.132 -p 10050 -k "Mysql.dml[192.168.128.132,root,123456,select]"
       ERROR 1045 (28000): Access denied for user 'root'@'node2' (using password: YES)    //出现这种情况是因为agent端的mysql无法解析主机名

    # vim /etc/my.cnf   //在agent端配置mysql配置文件跳过解析主机名

    skip_name_resolve = on

    在server端再次尝试即可获取

     

    但是从上面可以看到取得返回参数还是变量 + 数值

    # vim /etc/zabbix/zabbix_agentd.d/mysql.conf   //注意是agent端

    UserParameter=Mysql.dml[*], /usr/bin/mysql -h$1 -u$2 -p$3 -e 'SHOW GLOBAL STATUS' | awk '/Com_$4>/{print $$2}'  //注意这里后端的双引号改为单引号了,>词尾牟定

    # systemctl restart zabbix-agent

    在server端再次进行尝试,发现这次是可以的,所以在server端的测试和在agent端的测试有时是不同的

    # zabbix_get -s 192.168.128.132 -p 10050 -k "Mysql.dml[192.168.128.132,root,123456,select]"

    由于node1节点(即server端192.168.128.131)数据库比较丰富,所以这里对node1节点进行查询

    这里虽然是server端的mysql数据库,但是在定义items的时候是在node2上定义的,这个影响并不大

  • 相关阅读:
    c语言 12
    c语言中用结构体表示点的坐标,并计算两点之间的距离
    c语言 12
    c语言中结构体数组
    c语言 12-3
    c语言 12-2
    codevs3164 质因数分解
    codevs4438 YJQ Runs Upstairs
    codevs4439 YJQ Requires Food
    codevs4437 YJQ Arranges Sequences
  • 原文地址:https://www.cnblogs.com/hanshanxiaoheshang/p/10326636.html
Copyright © 2020-2023  润新知