1 自动发现已挂载的文件系统

Overview

可自动发现已挂载的文件系统及相关属性:

  • 挂载点名称
  • 文件系统类型
  • 文件系统大小
  • Inode 统计信息
  • 挂载选项

要想实现此功能,你可以使用:

  • 监控项vfs.fs.get 作为主监控项
  • 创建依赖监控项低级别自动发现规则和监控项原型

配置

主监控项

使用下面的键创建Zabbix agent监控项:

vfs.fs.get

JSON数据可能比较大,设置信息类型为 "Text"。

用于已挂载文件系统的监控项返回的数据会包含类似下面的信息:

{
         "fsname": "/",
         "fstype": "rootfs",
         "bytes": {
           "total": 1000,
           "free": 500,
           "used": 500,
           "pfree": 50.00,
           "pused": 50.00
         },
         "inodes": {
           "total": 1000,
           "free": 500,
           "used": 500,
           "pfree": 50.00,
           "pused": 50.00
         }
       }
依赖LLD规则

创建 "依赖监控项" 类型的低级别自动发现规则:

主监控项选择之前我们创建的 vfs.fs.get 监控项。.

在"LLD宏" 选项卡中自定义宏,使用对应的JSONPath:

你可以在 "过滤器" 选项中添加正则表达式来过滤 read-write 文件系统:

依赖监控项原型

在此LLD规则中创建一个监控项原型,类型选择 "依赖型监控项"。此原型的主监控项选择我们之前创建的 vfs.fs.get 监控项。

注意,对于监控项原型的名称和键,其自定义宏的使用方式:

  • 名称: {#FSNAME}上的空闲磁盘空间, 类型: {#FSTYPE}
  • : Free[{#FSNAME}]

使用以下信息类型,:

  • 数字 (无正负) 用于像 'free', 'total', 'used' 这样的指标
  • 浮点数 用于像 'pfree', 'pused' (百分比) 这样的指标

在监控项原型 "预处理" 选项中选择JSONPath并使用下面的 JSONPath表达式作为参数:

$.[?(@.fsname=='{#FSNAME}')].bytes.free.first()

一旦自动发现开始工作,每个挂载点会创建一个监控项。 监控项会返回对应挂载点的空闲空间大小(字节)。