zoukankan      html  css  js  c++  java
  • Zabbix 3.0 部署监控nginx

    一、添加监控主机及设置

     

    1.创建主机

    1.png-47.5kB
    2.png-52.5kB
    Agent可以干一些SNMP无法干的事情,例如自定义监控项 
    snmp相关文章:http://www.abcdocker.com/abcdocker/1376 
    3.png-32kB
    这里我们先不着急点add,还需要设置其他选项 
    1.png-17.4kB
    点击监控模板 
      zabbix监控是由监控项组成(cpu使用率监控就是一个监控项/内存使用率就是一个监控项),如果是100台服务器就需要监控模板了。只需要将监控项和模板关联起来即可 
    举个例子:我们上面主机使用的是SNMP,就可以直接搜索SNMP提示:有的模板需要自己定义 
    2.png-30.2kB
    温馨提示:请点击下面的小add 然后在点大的。否则会出现问题哦 
    1.png-32.6kB
    IPMI如果有的话,需要在这里写上用户名密码 
    2.png-23kB
    宏定义,这个宏其实就是一个变量。我们给可以给变量附一个值 
    3.png-15.1kB
      因为我们设置的是SNMPSNMP有一个团体名。并且可以设置定义 
      团体名是中间的abcdocker,具体的可以看http://www.abcdocker.com/abcdocker/1376

     
    1. [root@localhost ~]# cat /etc/snmp/snmpd.conf
    2. rocommunity abcdocker 192.168.56.11

    1.png-23.1kB
    值:{$SNMP_COMMUNITY} 
    2.png-43.1kB
    主机资产设置分为3中 
    1、关闭 Disabled 
    2、手动 Manual 
    3、自动 Automatic (自动代表的是你在定义监控项的时候,他有一个小箭头,勾上之后监控项的值就会填写在这里) 
       我们这设置好模板就可以选择add 
    3.png-43.8kB
    SNMP变绿就好了 
    4.png-52.6kB
      现在的状态是用SNMP进行监控了,我们只是添加了一个SNMP OS LINUX的模板,但是出现了4个。这4个链接。可以和多个模板连起来用 
    1.png-46.6kB
    进入监控项,下面这个菜单是过滤搜索用的 
    2.png-57.3kB
    下面全都是模板 
      我们可以随便点击一个,这里我们新建一个监控项 
    3.png-65.2kB
    点击创建 
    类型选择 
      Zabbix agent 被动 
      Zabbix agent (active主动模式) 
      Simple check 简单检测 
      SNMPv1 agent ...... 
    1.png-45kB
    在Key这行点击Select 可以进行选择 
    2.png-97.3kB
    我们随便选择一个,例如agent.version。查看agent的版本 
    Numeric是无符号整数型 
    1.png-20.3kB

     

    2.图形说明

    Configuration----hosts----Graphs 
    1.png-81.6kB
    绘图靠的是监控项,我们可以随便打开一个看看 
    2.png-58.6kB
    颜色等都是可以随意设置

     

    3、聚合图形screens设置

    1.png-42kB
    提示:因为咱们用的版本是3.0当2.4的时候需要在Configuration----下面来创建screens

    创建Screens 
    2.png-16.3kB
    我们创建一个2*2 命名为test screensscreens 
    3.png-37.5kB
    然后我们点进去 
    点击编辑 
    1.png-34.9kB
    点击Change进行设置 
    1.png-32.5kB
    2.png-25.8kB
    多添加几个之后就是以下结果 
    3.png-96.9kB

     

    二、监控案例[自定义监控项]

    例如:我们自己添加一个监控项来进行监控当前的活动连接数 [Nginx 安装请看上一篇] 
    nginx安装地址:http://www.abcdocker.com/abcdocker/1376 
    Nginx状态模块配置如下,过于简单不说了

     
    1. [root@localhost ~]# cat /usr/local/nginx/conf/nginx.conf
    2. listen 8080;
    3. location /status {
    4. stub_status on;
    5. access_log off;
    6. allow 192.168.56.0/24;
    7. deny all;
    8. }

    修改nginx端口并重启 
    测试:http://192.168.56.11:8080/status 
    1.png-8.7kB
    解释说明:使用zabbix来监控活动连接数,通过status状态模块为前提 
      我们现在命令取出我们想要的值,例如:

     
    1. [root@localhost ~]# curl -s http://192.168.56.11:8080/status|grep Active|awk -F "[ ]" '{print $3}'
    2. 1

    因为我们是监控他的活动连接数,他的活动连接数为1

     
    1. [root@linux-node1 ~]# vim /etc/zabbix/zabbix_agentd.conf
    2. Include=/etc/zabbix/zabbix_agentd.d/

    #提示: 如果想要加自定义监控项,不要在配置文件中写入,可以在Include里面定义的目录写上 
      只要我们写在Include目录下,都可以识别到

     
    1. [root@linux-node1 ~]# cd /etc/zabbix/zabbix_agentd.d/
    2. [root@linux-node1 zabbix_agentd.d]# ls
    3. userparameter_mysql.conf
    4. #默认有一个MySQL的,我们可以参考MySQL的进行操作
    5. UserParameter=mysql.ping,HOME=/var/lib/zabbix mysqladmin ping | grep -c alive
    6. #提示,前面是key的名称 后面的key的命令
    7. UserParameter=mysql.version,mysql -V

    我们自己编辑一个文件

     
    1. [root@linux-node1 zabbix_agentd.d]# cat nginx.conf
    2. UserParameter=nginx.active,/usr/bin/curl -s http://192.168.56.11:8080/status|grep Active|awk -F "[ ]" '{print $3}'
    3. #提示,此处配置文件的名字可以随便起

      如果是多个命令可以写一个脚本,命令最好写绝对路径!这个过程其实就是我们定义监控的过程,前面是key的名字,后面是命令 
    修改完配置文件之后需要重启zabbix-agent

     
    1. [root@linux-node1 zabbix_agentd.d]# systemctl restart zabbix-agent

      配置完成之后先在server端测试,是否可以获取到agent上的值。不要着急添加 
      我们现在只用了1台服务器,本机是server也是agent。然后使用zabbix-get进行测试

     
    1. [root@linux-node1 zabbix_agentd.d]# yum list|grep zabbix
    2. zabbix-agent.x86_64 3.0.4-1.el7 @zabbix
    3. zabbix-release.noarch 3.0-1.el7 installed
    4. zabbix-server-mysql.x86_64 3.0.4-1.el7 @zabbix
    5. zabbix-web.noarch 3.0.4-1.el7 @zabbix
    6. zabbix-web-mysql.noarch 3.0.4-1.el7 @zabbix
    7. python-pyzabbix.noarch 0.7.3-2.el7 epel
    8. uwsgi-stats-pusher-zabbix.x86_64 2.0.13.1-2.el7 epel
    9. zabbix-get.x86_64 3.0.4-1.el7 zabbix
    10. 查看zabbix_get
    11. [root@linux-node1 zabbix_agentd.d]# yum install -y zabbix-get

    zabbix-get使用参数如下:

     
    1. [root@linux-node1 zabbix_agentd.d]# zabbix_get -s 192.168.56.11 -p 10050 -k "nginx.active"
    2. -s 指定我们要查看的服务器
    3. -p 端口,可以不加。默认是10050
    4. -k 监控项的名称(根据上面的配置来定义的)
    5. 更多参数:zabbix_get --help
     

    错误案例:

    如果出现如下错误,大致意思是拒绝连接

     
    1. [root@linux-node1 zabbix_agentd.d]# zabbix_get -s 192.168.56.11 -p 10050 -k "nginx.active"
    2. zabbix_get [24234]: Check access restrictions in Zabbix agent configuration

    解决方法:

     
    1. [root@linux-node1 ~]# vim /etc/zabbix/zabbix_agentd.conf
    2. Server= 192.168.56.11

    因为我们当时只允许本机127.0.0.1进行连接。所以会出现这样问题

     
    1. [root@linux-node1 ~]# systemctl restart zabbix-agent

    修改完配置文件都要重启 
    提示: zabbix-agent的配置文件中指定允许那个server连接,那个才可以进行连接。

     
    1. [root@linux-node1 zabbix_agentd.d]# zabbix_get -s 192.168.56.11 -p 10050 -k "nginx.active"
    2. 1

    正确结果如上! 
    提示:如果在zabbix-agent上面修改了,还需要在网页上进行修改 
    1.png-73.8kB
    /etc/zabbix/zabbix-agent.conf上面指定的Server是谁,就只会允许谁通过。如果有多个ip可以使用逗号进行分割

     

    添加item

    2.png-97.6kB
    找到一个安装zabbix-agent,点击 
    3.png-80.8kB
    点击items 
    1.png-68.9kB
    然后添加Create item(创建item) 
    1.png-38.4kB
    2.png-4.3kB
    Data type:数据类型,这里我们选择Decimal。其他的基本上用不上 
    Units:单位 超过1千就写成1k了。 可以在这里做一个单位的设置。默认就可以 
    Use custom multiplier:如果这里面设置了一个数,得出来的结果都需要乘以文本框设定的值 
    1.png-17.2kB
    Update interval(in sec) 监控项刷新时间间隔(一般不要低于60秒) 
    Custom intervals 创建时间间隔(例如:1点-7点每隔多少秒进行监控)格式大致为:周,时,分 
    2.png-21.7kB
    History storage period 历史数据存储时间(根据业务来设置,默认就可以) 
    Trend storage period 趋势图要保存多久 
    New application 监控项的组 
    application 选择一个监控项组 
    Populates host inventory field 资产,可以设定一个监控项。把获取的值设置在资产上面 
    1.png-22.1kB
    描述!必须要写。 要不你就是不负责任 
    2.png-6.4kB
    添加自定义监控项小结: 
       1、添加用户自定义参数(在/etc/zabbix/zabbix.agent.d/定义了一个nginx.conf步骤如上) 
       2、重启zabbix-agent 
       3、在Server端使用zabbix_get测试获取(命令如上) 
       4、在web界面创建item(监控项) 
       

     

    自定义图形

    3.png-110.3kB
    Name:名字 
    Width:宽度 
    Height:高度 
    Graph type:图形类型 
    其他默认即可 
    1.png-45.3kB
    然后我们点击Add添加Items监控项,找到我们刚刚设置的服务器 
    2.png-145.4kB
    然后找到我们刚刚添加的监控项 
    3.png-11.2kB
    还可以选择颜色,添加其他的很多设置。不细说 
    4.png-36.5kB
      点击Prewview可以进行预览,如果出现字符乱码可以阅读我们另一篇文章(zabbix默认不支持中文) 
      确定没有问题,选择下方Add即可 
    5.png-92.3kB
    出现我们添加的 
    image_1at7vvch71hlq19i09hc1754tr6gp.png-75.2kB
    需要在Monitoring--->Graphs--->选择我们添加的主机即可 
    接下来我们需要进行测试 
    测试前: 
    6.png-13kB
    使用ab测试工具进行测试,设置100万并发进行访问

     
    1. [root@linux-node1 ~]# ab -c 1000 -n 1000000 http://192.168.56.11:8080/
    2. This is ApacheBench, Version 2.3 <$Revision: 1430300 $>
    3. Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
    4. Licensed to The Apache Software Foundation, http://www.apache.org/
    5. Benchmarking 192.168.56.11 (be patient)

    测试后: 
    1.png-14.5kB
    我们可以查看zabbix监控图标 
    2.png-69.9kB
    我们中间设置了间隔60秒,说明每隔60秒我们进行获取一次 
      我们可以设置它的方式显示 
    找到Graph选择类型,Stacked是堆叠显示,其他的大家可以自行百度。不细说 
      堆叠显示如下: 
    3.png-58.8kB
    如果我们想加多个图形都显示在一张图上,可以进行如下操作 
    4.png-57.1kB
    找到Graphs 
    5.png-89.8kB
    找到我们设置的图形 
    1.png-64.4kB
    点击添加即可

    我们可以让多个图标显示在一个图片上 
    2.png-41.9kB
    点击我们创建一个聚合图形(screens 
    1.png-45.5kB
    点击进去 
    2.png-40.5kB
    点击编辑 
    1.png-28.3kB
    选择item添加的地方,因为上面创建聚合图形的时候我们选择了2X2 所以这里会显示2个 
    2.png-53.8kB
    找到相对应的添加即可 
    我们可以多添加几个 
    3.png-60.3kB
    结果如上图显示 
    除了显示图片还可以显示其他内容 
    4.png-24.4kB

    Action log:日志
    Clock:时间
    Data overview:数据概述
    Graph:图形
    History of events:历史事件
    Host group issues:主机组问题
    Host issues:主机问题
    Hosts info:主机信息
    Plain text:文本
    Map:架构图
    Screen:屏幕
    Server info:服务器信息
    Simple graph:简单的图
    Simple graph prototype:简单的原型图
    System status:系统状态
    Triggers info:触发器信息
    Tiggers overview:概述
    URL:URL地址
    
     

    例如我们输入一个URL:

    1.png-24.4kB
    2.png-54.9kB
    我们还可以自定义一个Maps,一张架构图。操作如下: 
    3.png-45.4kB
    第二步:选择编辑Edit map 
    4.png-45.8kB
    因为他默认图片比较小,我们可以点击下方,进行调整图片大小。 
    5.png-41.4kB
    点击右上角编辑,然后我们点中图中的服务器即可 
    6.png-53.4kB
    我们模拟有2台服务器 
    7.png-47.6kB
    然后我们选中新添加的服务器进行修改 
    8.png-68.4kB
    点击Apply就可以了。 
    按住Ctrl点中zabbix server和另台服务器 
    9.png-63.9kB
    然后我们点击左上方的Link:他们就连接起来了 
    1.png-77.6kB
    温馨提示:修改完成后需要点击保存[update]如果不点后果就是从新在做一遍~ 
    2.png-49.7kB

    未完! 

    东方
  • 相关阅读:
    spring boot welcome-file-list
    spring boot web.xml listener
    Linkflow CDP
    连接数据,构建中台,Linkflow如何推动数据化浪潮 CDP
    客户全生命周期服务解决方案的提供商。
    自然语言处理的发展历史 发展方向 行业(法律)
    SpringBoot 设置 profiles 并在其他配置文件里面读取 pom.xml
    SpringBoot 配置文件无法解析占位符
    微服务 SaaS 低代码开发平台
    混沌工程与分布式系统
  • 原文地址:https://www.cnblogs.com/chenshengqun/p/7985656.html
Copyright © 2011-2022 走看看