• Zabbix Timeout 设置不当导致的问题


    哈喽大家好,我是咸鱼

    今天跟大家分享一个关于 zabbix Timeout 值设置不当导致的问题,这个问题不知道大家有没有碰到过

    问题

    事情经过是这样的:

    把某一台 zabbix agent 的模板由原来的 Template OS Windows by Zabbix agent 换成了 Template OS Windows by Zabbix agent active

    image

    Template OS Windows by Zabbix agent active 使用 主动模式 主动获取数据

    Template OS Windows by Zabbix agent 使用 被动模式 等待 Server 请求数据

    也就是说在主动模式下,Zabbix Agent 主动连接到 Zabbix Server 并发送监控数据,Zabbix Server 只需监听指定的端口,接收 Agent 发送过来的数据

    结果发现 zabbix server 接收不到数据

    排查

    查看 agent 日志(/var/log/zabbix/zabbix_agentd.log),发现 ZBX_TCP_READ() timed out

      8452:20230620:134942.947 active check configuration update from [192.168.149.129:10051] started to fail (ZBX_TCP_READ() timed out)
      8452:20230620:135044.072 active check configuration update from [192.168.149.129:10051] is working again
      8452:20230620:140049.959 active check configuration update from [192.168.149.129:10051] started to fail (ZBX_TCP_READ() timed out)
      8452:20230620:140149.093 active check configuration update from [192.168.149.129:10051] is working again
    

    而且经过进一步排查,发现:

    • server 节点运行正常,agent 节点正常运行
    • server 节点和 agent 节点之间可以 ping 通,而且 Telnet 端口可用

    综合上面的现象,怀疑是网络原因导致 TCP 建立连接时间超时,agent 向 server 发送数据失败

    既然是网络原因,那为什么我在修改模板(即被动模式)之前,server 是能够向 agent 获取数据的

    怎么被动模式就没超时,主动模式就超时了呢?

    解决

    在 Zabbix 中,timeout(超时)是指在进行监控数据获取或传输时,等待响应的时间限制

    在配置文件中如下所示,默认值是 3 s

    ### Option: Timeout
    #       Spend no more than Timeout seconds on processing
    # Timeout=3
    

    我们分别来看下 server 和 agent 关于超时时间的配置

    #server 端
    Timeout=30
    
    #agent 端
    Timeout=3
    

    可以看到,sever 端设置的超时时间是 30 s,agent 端设置的超时时间是 3s,这两个时间相差太大了吧

    如果 agent 的 timeout 设置得太短,可能会导致一些请求无法完成;而如果 server 的 timeout 设置得太短,可能会导致 agent 的请求被错误地判定为超时

    结合上面的情况,可以得知:

    • 主动模式下,agent 向 server 发送数据的时候,agent 端设置的超时时间是 3s,有可能会出现网络原因导致 TCP 建立连接时间超时,server 端获取不到数据,就会出现上面的问题
    • 被动模式下,server 向 agent 获取数据,但是 server 端设置的超时时间是 30s,这个超时时间可以说是非常大了

    我们把 agent 端的超时时间改一下,跟 server 端一致

    #agent 端
    Timeout=30
    

    重启 agent 后发现日志没有报 started to fail (ZBX_TCP_READ() timed out) 错,zabbix server 端也能够获取数据了
    image

    总结一下:

    • 在 Zabbix 中,timeout 是指在进行监控数据获取或传输时,等待响应时间的限制
    • Agent 和 Server 之间的超时时间设置应该相互协调,并根据实际网络状况和环境来进行调整。如果 Agent 的 timeout 设置得太短,可能会导致一些请求无法完成;而如果 Server 的 timeout 设置得太短,可能会导致 Agent 的请求被错误地判定为超时
    • 主动模式下 agent 的 timeout 值最好高于 server 配的 timeout 值,被动模式下 server 配的 timeout 值最好高于 agent 的 timeout

    If used with the passive agent, Timeout value in server configuration may need to be higher than Timeout in the agent configuration file. Otherwise the item may not get any value because the server request to agent timed out first.

  • 相关阅读:
    爬虫获取接口数据
    学校教务管理系统的设计与实现--Word文档可在最后链接处下载,无code
    Leetcode 1124. 表现良好的最长时间段
    企业电子招标采购系统源码Spring Boot + Mybatis + Redis + Layui + 前后端分离 构建企业电子招采平台之立项流程图
    centos8 编译安装 httpd-2.4
    Spring Cloud OpenFeign - - - > 契约配置
    Redis夺命十二问,差点没抗住
    0829学习笔记(gcc)
    Java 设计模式实战系列—策略模式
    单芯片3路CC管理的VR转接器解决方案
  • 原文地址:https://www.cnblogs.com/edisonfish/p/17503055.html