Grafana Dashboards

Basic CPU / Mem / Disk Info

1. CPU Cores 物理 CPU 的核数 cat /proc/cpuinfo| grep "cpu cores"| uniq

type:Singlestat
Unit: short
metrics:

count(count(node_cpu_seconds_total{instance=~\"$node:$port\",job=~\"$job\"}) by (cpu))

2. Total RAM 内存大小 cat /proc/meminfo | grep MemTotal

type:Singlestat
Unit: bytes
metrics:

node_memory_MemTotal_bytes{instance=~\"$node:$port\",job=~\"$job\"}

3. Total SWAP 交换分区的大小 cat /proc/swaps

type:Singlestat
Unit: bytes
metrics:

node_memory_SwapTotal_bytes{instance=~\"$node:$port\",job=~\"$job\"}

4. Total RootFS 根文件系统总空间

type:Singlestat
Unit: bytes
metrics:

node_filesystem_size_bytes{instance=~\"$node:$port\",job=~\"$job\",mountpoint=\"/\",fstype!=\"rootfs\"}

5. System Load (1m avg) 系统一分钟内的负载 cat /proc/loadavg 第一列,单核 cpu 的load小于1 表示没有等待的任务, 等于1 表示系统

已经没有额外的资源跑更多进程了,大于1表示进程拥堵在等待资源
type:Singlestat
Unit: short
metrics:

node_load1{instance=~\"$node:$port\",job=~\"$job\"}

6. Uptime 系统正常运行的时间

type:Singlestat
Unit: seconds (s)
metrics:

node_time_seconds{instance=~\"$node:$port\",job=~\"$job\"} - node_boot_time_seconds{instance=~\"$node:$port\",job=~\"$job\"}

node_time_seconds 当前系统时间
node_boot_time_seconds 系统启动时间

Basic CPU / Mem / Disk Gauge

1. CPU Busy :收集所有 cpu 内核 busy 状态占比

type: Singlestat
Unit: perent(0-100)
(所有 cpu使用情况 - 5分钟内 cpu 空闲的平均值) / 所有 cpu使用情况
metrics:

 (((count(count(node_cpu_seconds_total{instance=~\"$node:$port\",job=~\"$job\"}) by (cpu))) - avg(sum by (mode)(irate(node_cpu_seconds_total{mode='idle',instance=~\"$node:$port\",job=~\"$job\"}[5m])))) * 100) / count(count(node_cpu_seconds_total{instance=~\"$node:$port\",job=~\"$job\"}) by (cpu))

最大值: 100%

2. Used RAM Memory free -m

type: Singlestat
Unit: perent(0-100)
已使用的内存占比(包括Buffer缓存和Cached缓存)
metrics:

((node_memory_MemTotal_bytes{instance=~\"$node:$port\",job=~\"$job\"} - node_memory_MemFree_bytes{instance=~\"$node:$port\",job=~\"$job\"}) / (node_memory_MemTotal_bytes{instance=~\"$node:$port\",job=~\"$job\"} )) * 100

node_memory_MemFree_bytes 空闲内存

已使用的内存占比(不包括Buffer缓存和Cached缓存)
metrics:

100 - ((node_memory_MemAvailable_bytes{instance=~"$node:$port",job=~"$job"} * 100) / node_memory_MemTotal_bytes{instance=~"$node:$port",job=~"$job"})

MemAvailable: Free + Buffers + Cached - 不可回收的部分。不可回收部分包括:共享内存段,tmpfs,ramfs等

3. Used SWAP: 交换分区使用率

type: Singlestat
Unit: perent(0-100)
metrics:

((node_memory_SwapTotal_bytes{instance=~\"$node:$port\",job=~\"$job\"} - node_memory_SwapFree_bytes{instance=~\"$node:$port\",job=~\"$job\"}) / (node_memory_SwapTotal_bytes{instance=~\"$node:$port\",job=~\"$job\"} )) * 100

node_memory_SwapFree_bytes 交换分区的空闲大小

4. Used Root FS 根文件系统使用率

type: Singlestat
Unit: perent(0-100)
metrics:

100 - ((node_filesystem_avail_bytes{instance=~"$node:$port",job=~"$job",mountpoint="/",fstype!="rootfs"} * 100) / node_filesystem_size_bytes{instance=~"$node:$port",job=~"$job",mountpoint="/",fstype!="rootfs"})

node_filesystem_avail_bytes 文件系统可用空间

5. CPU System Load (1m avg) 一分钟内 CPU 所有内核的平均负载率

type: Singlestat
Unit: perent(0-100)
metrics:

avg(node_load1{instance=~"$node:$port",job=~"$job"}) /  count(count(node_cpu_seconds_total{instance=~"$node:$port",job=~"$job"}) by (cpu)) * 100

node_load1 : 系统一分钟内的负载

6. CPU System Load (5m avg) 五分钟内 CPU 所有内核的平均负载率

type: Singlestat
Unit: perent(0-100)
metrics:

avg(node_load5{instance=~"$node:$port",job=~"$job"}) /  count(count(node_cpu_seconds_total{instance=~"$node:$port",job=~"$job"}) by (cpu)) * 100

node_load5 : 指5分钟内cpu的负载

Basic CPU / Mem Graph

1. CPU Basic cpu 的基本信息 /proc/stat

type: Graph
Unit: short

Busy System: cpu 处于核心态的占比

metrics:

sum by (instance)(rate(node_cpu_seconds_total{mode="system",instance=~"$node:$port",job=~"$job"}[5m])) * 100

Busy User: cpu 处于用户态的占比

metrics:

sum by (instance)(rate(node_cpu_seconds_total{mode='user',instance=~"$node:$port",job=~"$job"}[5m])) * 100

Busy Iowait: cpu 处于 io 等待的时间占比

metrics:

sum by (instance)(rate(node_cpu_seconds_total{mode='iowait',instance=~"$node:$port",job=~"$job"}[5m])) * 100

Busy IRQs: cpu 处于中断状态占比

metrics:

sum by (instance)(rate(node_cpu_seconds_total{mode=~".*irq",instance=~"$node:$port",job=~"$job"}[5m])) * 100

Idle: cpu 处于空闲状态占比

metrics:

sum by (mode)(rate(node_cpu_seconds_total{mode='idle',instance=~"$node:$port",job=~"$job"}[5m])) * 100

Busy Other: cpu 处于其他状态占比(非系统状态、非用户态、非io等待状态、非空闲态、非中断状态)

metrics:

sum (rate(node_cpu_seconds_total{mode!='idle',mode!='user',mode!='system',mode!='iowait',mode!='irq',mode!='softirq',instance=~"$node:$port",job=~"$job"}[5m])) * 100

2. Memory Basic 内存基本信息

type: Graph
Unit: short

RAM Total: 内存大小

metrics:

node_memory_MemTotal_bytes{instance=~"$node:$port",job=~"$job"}

RAM Used: 已使用的内存大小(内存总量-空闲的内存大小-Buffer缓存和Cached缓存占的内存大小)

metrics:

node_memory_MemTotal_bytes{instance=~"$node:$port",job=~"$job"} - node_memory_MemFree_bytes{instance=~"$node:$port",job=~"$job"} - (node_memory_Cached_bytes{instance=~"$node:$port",job=~"$job"} + node_memory_Buffers_bytes{instance=~"$node:$port",job=~"$job"})

RAM Cache + Buffer: Cached缓存占的内存大小

metrics:

node_memory_Cached_bytes{instance=~"$node:$port",job=~"$job"} + node_memory_Buffers_bytes{instance=~"$node:$port",job=~"$job"}

RAM Free: 空闲的内存大小

metrics:

node_memory_MemFree_bytes{instance=~"$node:$port",job=~"$job"}

SWAP Used: 已使用的交换内存的大小

metrics:

(node_memory_SwapTotal_bytes{instance=~"$node:$port",job=~"$job"} - node_memory_SwapFree_bytes{instance=~"$node:$port",job=~"$job"})
交换分区的总大小- 空闲大小

Basic Net / Disk Info

1. Network Traffic Basic 每个接口的基本网络信息

type: Graph
Unit: bytes

recv {{device}} 各个网络接口的下载量

recv lo: 本地环回接口
recv eth0: 以太网接口
recv docker0: docker0 网络接口
metrics:

rate(node_network_receive_bytes_total{instance=~"$node:$port",job=~"$job"}[5m])

trans {{device}} 各个网络接口的上传量

metrics:

rate(node_network_transmit_bytes_total{instance=~"$node:$port",job=~"$job"}[5m])

2. Disk Space Used Basic 所有挂载的文件系统的磁盘空间占比

type: Graph
unit: perent(0-100)
metrics:

100 - ((node_filesystem_avail_bytes{instance=~"$node:$port",job=~"$job",device!~'rootfs'} * 100) / node_filesystem_size_bytes{instance=~"$node:$port",job=~"$job",device!~'rootfs'})

CPU Memory Net Disk

1. CPU

type: Graph
Unit: short
max: "100"
min: "0"
Label: Percentage

System - cpu 在内核模式下执行的进程占比

metrics:

sum by (mode)(irate(node_cpu_seconds_total{mode="system",instance=~"$node:$port",job=~"$job"}[5m])) * 100

User - cpu 在用户模式下执行的正常进程占比

metrics:

sum by (mode)(irate(node_cpu_seconds_total{mode='user',instance=~"$node:$port",job=~"$job"}[5m])) * 100

Nice - cpu 在用户模式下执行的 nice 进程占比

metrics:

sum by (mode)(irate(node_cpu_seconds_total{mode='nice',instance=~"$node:$port",job=~"$job"}[5m])) * 100

Idle - cpu 在空闲模式下的占比

metrics:

sum by (mode)(irate(node_cpu_seconds_total{mode='idle',instance=~"$node:$port",job=~"$job"}[5m])) * 100

Iowait - cpu 在 io 等待的占比

metrics:

sum by (mode)(irate(node_cpu_seconds_total{mode='iowait',instance=~"$node:$port",job=~"$job"}[5m])) * 100

Irq - cpu 在服务中断的占比

metrics:

sum by (mode)(irate(node_cpu_seconds_total{mode='irq',instance=~"$node:$port",job=~"$job"}[5m])) * 100

Softirq - cpu 在服务软中断的占比

metrics:

sum by (mode)(irate(node_cpu_seconds_total{mode='softirq',instance=~"$node:$port",job=~"$job"}[5m])) * 100

Steal - 在 VM 中运行时其他 VM 占用的本 VM 的 cpu 的占比

metrics:

sum by (mode)(irate(node_cpu_seconds_total{mode='steal',instance=~"$node:$port",job=~"$job"}[5m])) * 100

Guest - 运行各种 VM 使用的 CPU 占比

metrics:

sum by (mode)(irate(node_cpu_seconds_total{mode='guest',instance=~"$node:$port",job=~"$job"}[5m])) * 100

2. Memory Stack 内存堆栈 /proc/meminfo

type: Graph
Unit: bytes
min: "0"
Label: Bytes

Apps - 用户空间应用程序使用的内存

metrics:

node_memory_MemTotal_bytes{instance=~"$node:$port",job=~"$job"} - node_memory_MemFree_bytes{instance=~"$node:$port",job=~"$job"} 
- node_memory_Buffers_bytes{instance=~"$node:$port",job=~"$job"} - node_memory_Cached_bytes{instance=~"$node:$port",job=~"$job"} 
- node_memory_Slab_bytes{instance=~"$node:$port",job=~"$job"} - node_memory_PageTables_bytes{instance=~"$node:$port",job=~"$job"} 
- node_memory_SwapCached_bytes{instance=~"$node:$port",job=~"$job"}

PageTables - 用于在虚拟和物理内存地址之间映射的内存

metrics:

node_memory_PageTables_bytes{instance=~"$node:$port",job=~"$job"}

SwapCache - 用于跟踪已从交换区中提取出来但尚未修改的页面的内存

metrics:

node_memory_SwapCached_bytes{instance=~"$node:$port",job=~"$job"}

Slab - 内核用于缓存数据结构以供自己使用的内存(如 inode,dentry 等缓存)

metrics:

node_memory_Slab_bytes{instance=~"$node:$port",job=~"$job"}

Cache - 频繁访问的文件数据或内容的缓存

metrics:

node_memory_Cached_bytes{instance=~"$node:$port",job=~"$job"}

Buffers - 块设备(例如硬盘)缓存

metrics:

node_memory_Buffers_bytes{instance=~"$node:$port",job=~"$job"}

Unused - 未使用的内存大小

metrics:

node_memory_MemFree_bytes{instance=~"$node:$port",job=~"$job"}

Swap - 交换分区使用的空间

metrics:

(node_memory_SwapTotal_bytes{instance=~"$node:$port",job=~"$job"} - node_memory_SwapFree_bytes{instance=~"$node:$port",job=~"$job"})

Harware Corrupted - 内核识别为已损坏或不工作的内存量

metrics:

node_memory_HardwareCorrupted_bytes{instance=~"$node:$port",job=~"$job"}

3. Network Traffic 各个网络接口的传输速率

type: Graph
Unit: bytes/sec
Label: Bytes out(-)/in(+)

{{device}} - Receive 各个网络接口下载速率

metrics:

irate(node_network_receive_bytes_total{instance=~"$node:$port",job=~"$job"}[5m])

{{device}} - Transmit 各个网络接口上传速率

metrics:

irate(node_network_transmit_bytes_total{instance=~"$node:$port",job=~"$job"}[5m])

4. Disk Space Used 所有挂载的文件系统的磁盘空间大小

type: Graph
Unit: bytes
min: "0"
Label: Bytes
metrics:

node_filesystem_size_bytes{instance=~"$node:$port",job=~"$job",device!~'rootfs'} - node_filesystem_avail_bytes{instance=~"$node:$port",job=~"$job",device!~'rootfs'}

5. Disk IOps 磁盘读写

type: Graph
Unit: I/O ops/sec (iops)
Label: IO read(-)/write(+)

{{device}} - Reads completed 磁盘的读取速率(五分钟内)

metrics:

irate(node_disk_reads_completed_total{instance=~"$node:$port",job=~"$job",device=~"[a-z]*[a-z]"}[5m])

{{device}} - Writes completed 磁盘的写入速率(五分钟内)

metrics:

irate(node_disk_writes_completed_total{instance=~"$node:$port",job=~"$job",device=~"[a-z]*[a-z]"}[5m])

6. I/O Usage Read / Write

type: Graph
Unit: bytes
Label: Bytes read(-)/write(+)

成功读取的字节数(五分钟内)

metrics:

irate(node_disk_read_bytes_total{instance=~"$node:$port",job=~"$job",device=~"[a-z]*[a-z]"}[5m])

成功写入的字节数(五分钟内)

metrics:

irate(node_disk_written_bytes_total{instance=~"$node:$port",job=~"$job",device=~"[a-z]*[a-z]"}[5m])

7. I/O Usage Times 使用 I/O 的毫秒数

type: Graph
Unit: ms
Label: Milliseconds
metrics:

irate(node_disk_io_time_seconds_total{instance=~"$node:$port",job=~"$job",device=~"[a-z]*[a-z]"} [5m])

Memory Detail Meminfo /proc/meminfo

1. Memory Active / Inactive

type: Graph
Unit: bytes
Label: Bytes

Inactive - 最近使用较少的内存, 优先被回收利用 /proc/meminfo Inactive

metrics:

node_memory_Inactive_bytes{instance=~"$node:$port",job=~"$job"}

Active - 最近被频繁使用的内存,除非绝对必要,否则通常不会回收 /proc/meminfo Active

metrics:

node_memory_Active_bytes{instance=~"$node:$port",job=~"$job"}

2. Memory Commited

type: Graph
Unit: bytes
Label: Bytes

Committed_AS - 当前系统已经分配的内存量,包括已分配但尚未使用的内存大小 /proc/meminfo Committed_AS

metrics:

node_memory_Committed_AS_bytes{instance=~"$node:$port",job=~"$job"}

CommitLimit - 当前系统可分配的内存量 /proc/meminfo CommitLimit

metrics:

node_memory_CommitLimit_bytes{instance=~"$node:$port",job=~"$job"}

3. Memory Active / Inactive Detail

type: Graph
Unit: bytes
Label: Bytes

Inactive_file - LRU list 上长时间未被访问过的与文件对应的内存页 /proc/meminfo LRU_INACTIVE_FILE

metrics:

node_memory_Inactive_file_bytes{instance=~"$node:$port",job=~"$job"}

Inactive_anon - 上长时间未被访问过的匿名页和交换区缓存(包括 tmpfs) /proc/meminfo LRU_INACTIVE_ANON

metrics:

node_memory_Inactive_anon_bytes{instance=~"$node:$port",job=~"$job"}

Active_file - LRU list 最近被访问过的与文件对应的内存页 /proc/meminfo LRU_ACTIVE_FILE

metrics:

node_memory_Active_file_bytes{instance=~"$node:$port",job=~"$job"}

Active_anon - 最近被访问过的匿名页和交换区缓存(包括 tmpfs) /proc/meminfo LRU_ACTIVE_ANON

metrics:

node_memory_Active_anon_bytes{instance=~"$node:$port",job=~"$job"}

4. Memory Writeback and Dirty

type: Graph
Unit: bytes
Label: Bytes

Writeback - 正准备主动回写硬盘的缓存页 /proc/meminfo Writeback

metrics:

node_memory_Writeback_bytes{instance=~"$node:$port",job=~"$job"}

WritebackTmp - FUSE用于临时写回缓冲区的内存 /proc/meminfo WritebackTmp

metrics:

node_memory_WritebackTmp_bytes{instance=~"$node:$port",job=~"$job"}

Dirty - 需要写回磁盘的数据大小 /proc/meminfo Dirty

metrics:

node_memory_Dirty_bytes{instance=~"$node:$port",job=~"$job"}

5. Memory Shared and Mapped

type: Graph
Unit: bytes
Label: Bytes

Mapped - mapped 缓存页占用的内存 /proc/meminfo Mapped

metrics:

node_memory_Mapped_bytes{instance=~"$node:$port",job=~"$job"}

Shmem - 共享内存 /proc/meminfo Shared

metrics:

node_memory_Shmem_bytes{instance=~"$node:$port",job=~"$job"}

6. Memory Slab

type: Graph
Unit: bytes
Label: Bytes

SUnreclaim - 通过slab分配的内存中不可回收的部分 /proc/meminfo SUnreclaim

metrics:

node_memory_SUnreclaim_bytes{instance=~"$node:$port",job=~"$job"}

SReclaimable - 通过slab分配的内存中可回收的部分 /proc/meminfo SReclaimable

metrics:

node_memory_SReclaimable_bytes{instance=~"$node:$port",job=~"$job"}

7. Memory Vmalloc

type: Graph
Unit: bytes
Label: Bytes

VmallocChunk - vmalloc 可分配的最大的逻辑连续的内存大小 /proc/meminfo VmallocChunk

metrics:

node_memory_VmallocChunk_bytes{instance=~"$node:$port",job=~"$job"}

VmallocTotal - vmalloc 可使用的总内存大小 /proc/meminfo VmallocTotal

metrics:

node_memory_VmallocTotal_bytes{instance=~"$node:$port",job=~"$job"}

VmallocUsed - vmalloc 已用的总内存大小 /proc/meminfo VmallocUsed

metrics:

node_memory_VmallocUsed_bytes{instance=~"$node:$port",job=~"$job"}

8. Memory Bounce /proc/meminfo Bounce

type: Graph
Unit: bytes
Label: Bytes

Bounce - bounce buffers 占用的内存

metrics:

node_memory_Bounce_bytes{instance=~"$node:$port",job=~"$job"}

9. Memory Anonymous

type: Graph
Unit: bytes
Label: Bytes

AnonHugePages - AnonHugePages 占用的内存大小 /proc/meminfo AnonHugePages

metrics:

node_memory_AnonHugePages_bytes{instance=~"$node:$port",job=~"$job"}

AnonPages - 用户进程中匿名内存页大小 /proc/meminfo AnonPages

metrics:

node_memory_AnonPages_bytes{instance=~"$node:$port",job=~"$job"}

10. Memory Kernel /proc/meminfo KernelStack

type: Graph
Unit: bytes
Label: Bytes

KernelStack - 内核栈大小(常驻内存,不可回收)

metrics:

node_memory_KernelStack_bytes{instance=~"$node:$port",job=~"$job"}

11. Memory HugePages Counter

type: Graph
Unit: short
Label: Pages

HugePages_Free - 系统当前总共拥有的空闲 HugePages 数目 /proc/meminfo HugePages_Free

metrics:

node_memory_HugePages_Free{instance=~"$node:$port",job=~"$job"}

HugePages_Rsvd - 系统当前总共保留的HugePages数目,更具体点就是指程序已经向系统申请,但是由于程序还没有实质的HugePages读写操作,因此系统尚未实际分配给程序的HugePages数目 /proc/meminfo HugePages_Rsvd

metrics:

node_memory_HugePages_Rsvd{instance=~"$node:$port",job=~"$job"}

HugePages_Surp - 指超过系统设定的常驻HugePages数目的数目 /proc/meminfo HugePages_Surp

metrics:

node_memory_HugePages_Surp{instance=~"$node:$port",job=~"$job"}

12. Memory HugePages Size

type: Graph
Unit: bytes
Label: Bytes

HugePages - 系统当前总共拥有的HugePages数目 /proc/meminfo HugePages

metrics:

node_memory_HugePages_Total{instance=~"$node:$port",job=~"$job"}

Hugepagesize - 每一页 HugePages 的大小 /proc/meminfo Hugepagesize

metrics:

node_memory_Hugepagesize_bytes{instance=~"$node:$port",job=~"$job"}

13. Memory DirectMap /proc/meminfo DirectMap

type: Graph
Unit: bytes
Label: Bytes

DirectMap1G - 映射为 1G 的内存页的内存数量

metrics:

node_memory_DirectMap1G{instance=~"$node:$port",job=~"$job"}

DirectMap2M - 映射为 2M 的内存页的内存数量

metrics:

node_memory_DirectMap2M_bytes{instance=~"$node:$port",job=~"$job"}

DirectMap4K - 映射为 4kB 的内存页的内存数量

metrics:

node_memory_DirectMap4k_bytes{instance=~"$node:$port",job=~"$job"}

14. Memory Unevictable and MLocked

type: Graph
Unit: bytes
Label: Bytes

Unevictable - 不可被回收的内存 /proc/meminfo Unevictable

metrics:

node_memory_Unevictable_bytes{instance=~"$node:$port",job=~"$job"}

MLocked - 被mlock()系统调用锁定的内存大小 /proc/meminfo MLocked

metrics:

node_memory_Mlocked_bytes{instance=~"$node:$port",job=~"$job"}

15. Memory NFS /proc/meminfo NFS_Unstable

type: Graph
Unit: bytes
Label: Bytes

NFS Unstable - 发给NFS server但尚未写入硬盘的缓存页

metrics:

node_memory_NFS_Unstable_bytes{instance=~"$node:$port",job=~"$job"}

Memory Detail Vmstat

1. Memory Pages In / Out

type: Graph
Unit: short
Label: Pages

Pagesin - 数据从硬盘读到物理内存的速率(5分钟内) /proc/vmstat pgpgin

metrics:

irate(node_vmstat_pgpgin{instance=~"$node:$port",job=~"$job"}[5m])

Pagesout - 数据从物理内存写到硬盘的速率(5分钟内) /proc/vmstat pgpgout

metrics:

irate(node_vmstat_pgpgout{instance=~"$node:$port",job=~"$job"}[5m])

2. Memory Pages Swap In / Out

type: Graph
Unit: short
Label: Pages

Pswpin - 数据从磁盘交换区装入内存的速率(5分钟内) /proc/vmstat pswpin

metrics:

irate(node_vmstat_pswpin{instance=~"$node:$port",job=~"$job"}[5m])

Pswpout - 数据从内存转储到磁盘交换区的速率(5分钟内) /proc/vmstat pswpout

metrics:

irate(node_vmstat_pswpout{instance=~"$node:$port",job=~"$job"}[5m])

3. Memory Page Operations

type: Graph
Unit: short
Label: Pages

Pgdeactivate - 激活的平均页数(5分钟内) /proc/vmstat pgdeactivate

metrics:

irate(node_vmstat_pgdeactivate{instance=~"$node:$port",job=~"$job"}[5m])

Pgfree - 释放的平均页数(5分钟内) /proc/vmstat pgfree

metrics:

irate(node_vmstat_pgfree{instance=~"$node:$port",job=~"$job"}[5m])

Pgactivate - 未激活的平均页数(5分钟内) /proc/vmstat pgactivate

metrics:

irate(node_vmstat_pgactivate{instance=~"$node:$port",job=~"$job"}[5m])

4. Memory Page Faults

type: Graph
Unit: short
Label: Faults

Pgfault - 一级页面和二级页面的平均错误数(5分钟内) /proc/vmstat pgfault

metrics:

irate(node_vmstat_pgfault{instance=~"$node:$port",job=~"$job"}[5m])

Pgmajfault - 一级页面的平均错误数(5分钟内) /proc/vmstat pgmajfault

metrics:

irate(node_vmstat_pgmajfault{instance=~"$node:$port",job=~"$job"}[5m])

Pgminfault - 二级页面的平均错误数(5分钟内)

metrics:

irate(node_vmstat_pgfault{instance=~"$node:$port",job=~"$job"}[5m])  - irate(node_vmstat_pgmajfault{instance=~"$node:$port",job=~"$job"}[5m])

5. Memory Pages Reclaimed

type: Graph
Unit: short
Label: Pages

Kswapd_inodesteal - 由 kswapd 回收用于其它目的的平均页面数(5分钟内) /proc/vmstat kswapd_inodesteal

metrics:

irate(node_vmstat_kswapd_inodesteal{instance=~"$node:$port",job=~"$job"}[5m])

Pgindesteal - 由 inode 释放回收的平均页面数(5分钟内) /proc/vmstat pgindesteal

metrics:

irate(node_vmstat_pginodesteal{instance=~"$node:$port",job=~"$job"}[5m])

6. Memory Calls Reclaimed

type: Graph
Unit: short
Label: Cells

Pageoutrun - 由 kswapd调用来回收的平均页面数(5分钟内) /proc/vmstatpageoutrun

metrics:

irate(node_vmstat_pageoutrun{instance=~"$node:$port",job=~"$job"}[5m])

Allocstall - 请求直接回收的平均页面数(5分钟内) /proc/vmstat allocstall

metrics:

irate(node_vmstat_allocstall{instance=~"$node:$port",job=~"$job"}[5m])

Zone_reclaim_failed - 内存域回收失败的平均页面数(5分钟内) /proc/vmstat zone_reclaim_failed

metrics:

irate(node_vmstat_zone_reclaim_failed{instance=~"$node:$port",job=~"$job"}[5m])

7. Memory Page Rotate /proc/vmstat pgrotated

type: Graph
Unit: short
Label: Pages

Pgrotated - 轮换的平均页面数(5分钟内)

metrics:

irate(node_vmstat_pgrotated{instance=~"$node:$port",job=~"$job"}[5m])

8. Memory Page Drop

type: Graph
Unit: short
Label: Cells

Drop_pagecache - 调用释放缓存的平均页面数(5分钟内) /proc/vmstat drop_pagecache

metrics:

node_vmstat_drop_pagecache{instance=~"$node:$port",job=~"$job"}

Drop_slab - 调用释放 slab 缓存的平均页面数(5分钟内) /proc/vmstat drop_slab

metrics:

node_vmstat_drop_slab{instance=~"$node:$port",job=~"$job"}

9. Memory Scan Slab /proc/vmstat slabs_scanned

type: Graph
Unit: short

Slabs_scanned - 被扫描的 Slab 页面的平均页面数(5分钟内)

metrics:

irate(node_vmstat_slabs_scanned{instance=~"$node:$port",job=~"$job"}[5m])

10. Memory Unevictable Pages

type: Graph
Unit: short
Label: Pages

Unevictable_pgs_cleared - Unevictable pages cleared

metrics:

irate(node_vmstat_unevictable_pgs_cleared{instance=~"$node:$port",job=~"$job"}[5m])

Unevictable_pgs_culled - Unevictable pages culled

metrics:

irate(node_vmstat_unevictable_pgs_culled{instance=~"$node:$port",job=~"$job"}[5m])

Unevictable_pgs_mlocked - Unevictable pages mlocked

metrics:

irate(node_vmstat_unevictable_pgs_mlocked{instance=~"$node:$port",job=~"$job"}[5m])

Unevictable_pgs_munlocked - Unevictable pages munlocked

metrics:

irate(node_vmstat_unevictable_pgs_munlocked{instance=~"$node:$port",job=~"$job"}[5m])

Unevictable_pgs_rescued- Unevictable pages rescued

metrics:

irate(node_vmstat_unevictable_pgs_rescued{instance=~"$node:$port",job=~"$job"}[5m])

Unevictable_pgs_scanned - Unevictable pages scanned

metrics:

irate(node_vmstat_unevictable_pgs_scanned{instance=~"$node:$port",job=~"$job"}[5m])

unevictable_pgs_stranded - Unevictable pages stranded

metrics:

irate(node_vmstat_unevictable_pgs_stranded{instance=~"$node:$port",job=~"$job"}[5m])

11. Memory Page Allocation

type: Graph
Unit: short
Label: Pages

Pgalloc_dma - DMA 存储区分配的平均页数(5分钟内) /proc/vmstat pgalloc_dma

metrics:

irate(node_vmstat_pgalloc_dma{instance=~"$node:$port",job=~"$job"}[5m])

Pgalloc_dma32 - DMA32 存储区分配的平均页数(5分钟内) /proc/vmstat pgalloc_dma32

metrics:

irate(node_vmstat_pgalloc_dma32{instance=~"$node:$port",job=~"$job"}[5m])

Pgalloc_movable - movable 存储区分配的平均页数(5分钟内) /proc/vmstat pgalloc_movable

metrics:

irate(node_vmstat_pgalloc_movable{instance=~"$node:$port",job=~"$job"}[5m])

Pgalloc_normal - 普通存储区分配的平均页数(5分钟内) /proc/vmstat pgalloc_normal

metrics:

irate(node_vmstat_pgalloc_normal{instance=~"$node:$port",job=~"$job"}[5m])

12. Memory Page Refill

type: Graph
Unit: short
Label: Pages

Pgrefill_dma - DMA 再填充的平均页数(5分钟内) /proc/vmstat pgrefill_dma

metrics:

irate(node_vmstat_pgrefill_dma{instance=~"$node:$port",job=~"$job"}[5m])

Pgrefill_dma32 - DMA32 存储区再填充的平均页数(5分钟内) /proc/vmstat pgrefill_dma32

metrics:

irate(node_vmstat_pgrefill_dma32{instance=~"$node:$port",job=~"$job"}[5m])

Pgrefill_movable - movable 存储区再填充的平均页数(5分钟内) /proc/vmstat pgrefill_movable

metrics:

irate(node_vmstat_pgrefill_movable{instance=~"$node:$port",job=~"$job"}[5m])

Pgrefill_normal - 普通存储区再填充的平均页数(5分钟内) /proc/vmstat pgrefill_normal

metrics:

irate(node_vmstat_pgrefill_normal{instance=~"$node:$port",job=~"$job"}[5m])

13. Memory Page Steal Direct

type: Graph
Unit: short
Label: Pages

Pgsteal_direct_dma - DMA 存储区被直接回收用于其它目的的平均页面数(5分钟内) /proc/vmstat pgsteal_direct_dma

metrics:

irate(node_vmstat_pgsteal_direct_dma{instance=~"$node:$port",job=~"$job"}[5m])

Pgsteal_direct_dma32 - DMA32 存储区被直接回收用于其它目的的平均页面数(5分钟内) /proc/vmstat pgsteal_direct_dma32

metrics:

irate(node_vmstat_pgsteal_direct_dma32{instance=~"$node:$port",job=~"$job"}[5m])

Pgsteal_direct_movable - movable 存储区被直接回收用于其它目的的平均页面数(5分钟内) /proc/vmstat pgsteal_direct_movable

metrics:

irate(node_vmstat_pgsteal_direct_movable{instance=~"$node:$port",job=~"$job"}[5m])

Pgsteal_direct_normal - 普通存储区被直接回收用于其它目的的平均页面数(5分钟内) /proc/vmstat pgsteal_direct_normal

metrics:

irate(node_vmstat_pgsteal_direct_normal{instance=~"$node:$port",job=~"$job"}[5m])

14. Memory Page Steal Kswapd

type: Graph
Unit: short
Label: Pages

Pgsteal_kswapd_dma - kswapd 后台进程回收 DMA 存储区用于其它目的的平均页面数(5分钟内) /proc/vmstat pgsteal_kswapd_dma

metrics:

irate(node_vmstat_pgsteal_kswapd_dma{instance=~"$node:$port",job=~"$job"}[5m])

Pgsteal_kswapd_dma32 - kswapd 后台进程回收 DMA32 存储区用于其它目的的平均页面数(5分钟内) /proc/vmstat pgsteal_kswapd_dma32

metrics:

irate(node_vmstat_pgsteal_kswapd_dma32{instance=~"$node:$port",job=~"$job"}[5m])

Pgsteal_kswapd_movable - kswapd 后台进程回收 movable 存储区用于其它目的的平均页面数(5分钟内 /proc/vmstat pgsteal_kswapd_movable

metrics:

irate(node_vmstat_pgsteal_kswapd_movable{instance=~"$node:$port",job=~"$job"}[5m])

Pgsteal_kswapd_normal - swapd后台进程回收普通存储区用于其它目的的平均页面数(5分钟内 /proc/vmstat pgsteal_kswapd_normal

metrics:

irate(node_vmstat_pgsteal_kswapd_normal{instance=~"$node:$port",job=~"$job"}[5m])

15. Memory Scan Direct

type: Graph
Unit: short
Label: Pages

Pgscan_direct_dma - DMA 存储区被直接回收的平均页面数(5分钟内) /proc/vmstat pgscan_direct_dma

metrics:

irate(node_vmstat_pgscan_direct_dma{instance=~"$node:$port",job=~"$job"}[5m])

Pgscan_direct_dma32 - DMA32 存储区被直接回收的平均页面数(5分钟内) /proc/vmstat pgscan_direct_dma32

metrics:

irate(node_vmstat_pgscan_direct_dma32{instance=~"$node:$port",job=~"$job"}[5m])

Pgscan_direct_movable - movable 存储区被直接回收的平均页面数(5分钟内) /proc/vmstat pgscan_direct_movable

metrics:

irate(node_vmstat_pgscan_direct_movable{instance=~"$node:$port",job=~"$job"}[5m])

Pgscan_direct_normal - 普通存储区被直接回收的平均页面数(5分钟内) /proc/vmstat pgscan_direct_normal

metrics:

irate(node_vmstat_pgscan_direct_normal{instance=~"$node:$port",job=~"$job"}[5m])

Pgscan_direct_throttle - throttle 存储区被直接回收的平均页面数(5分钟内) /proc/vmstat pgscan_direct_throttle

metrics:

irate(node_vmstat_pgscan_direct_throttle{instance=~"$node:$port",job=~"$job"}[5m])

16. Memory Scan Kswapd

type: Graph
Unit: short
Label: Pages

Pgscan_kswapd_dma - kswapd 后台进程扫描的 DMA 存储区平均页面数(5分钟内) /proc/vmstat pgscan_kswapd_dma

metrics:

irate(node_vmstat_pgscan_kswapd_dma{instance=~"$node:$port",job=~"$job"}[5m])

Pgscan_kswapd_dma32 - kswapd 后台进程扫描的 DMA32 存储区平均页面数(5分钟内) /proc/vmstat pgscan_kswapd_dma32

metrics:

irate(node_vmstat_pgscan_kswapd_dma32{instance=~"$node:$port",job=~"$job"}[5m])

Pgscan_kswapd_movable - kswapd 后台进程扫描的 movable 存储区平均页面数(5分钟内) /proc/vmstat pgscan_kswapd_movable

metrics:

irate(node_vmstat_pgscan_kswapd_movable{instance=~"$node:$port",job=~"$job"}[5m])

Pgscan_kswapd_normal - kswapd 后台进程扫描的普通存储区平均页面数(5分钟内) /proc/vmstat pgscan_kswapd_normal

metrics:

irate(node_vmstat_pgscan_kswapd_normal{instance=~"$node:$port",job=~"$job"}[5m])

17. Memory Page Compact

type: Graph
Unit: short
Label: Pages

Compact_free_scanned - 扫描由压缩守护程序释放的页面 /proc/vmstat compact_free_scanned

metrics:

irate(node_vmstat_compact_free_scanned{instance=~"$node:$port",job=~"$job"}[5m])

Compact_isolated - 用于内存压缩隔离的页面 /proc/vmstat compact_isolated

metrics:

irate(node_vmstat_compact_isolated{instance=~"$node:$port",job=~"$job"}[5m])

Compact_migrate_scanned - 通过内存压缩守护程序扫描以进行迁移的页面 /proc/vmstat compact_migrate_scanned

metrics:

irate(node_vmstat_compact_migrate_scanned{instance=~"$node:$port",job=~"$job"}[5m])

18. Memory Compactions 内存紧缩

type: Graph
Unit: short
Label: Compactions

Compact_fail - 高阶分配的内存碎片整理失败的页面数(5分钟内) /proc/vmstat compact_fail

metrics:

irate(node_vmstat_compact_fail{instance=~"$node:$port",job=~"$job"}[5m])

Compact_stall - 开始执行内存碎片失败的页面数(5分钟内) /proc/vmstat compact_stall

metrics:

irate(node_vmstat_compact_stall{instance=~"$node:$port",job=~"$job"}[5m])

Compact_sucess - 高阶分配的内存碎片整理成功的页面数(5分钟内)

metrics:

irate(node_vmstat_compact_success{instance=~"$node:$port",job=~"$job"}[5m])

19. Memory Kswapd Watermark

type: Graph
Unit: short
Label: Counter

Kswapd_high_wmark_hit_quickly - 剩余内存达到 high 的水位线的时间 /proc/vmstat kswapd_high_wmark_hit_quickly

metrics:

node_vmstat_kswapd_high_wmark_hit_quickly{instance=~"$node:$port",job=~"$job"}

Kswapd_low_wmark_hit_quickly - - 剩余内存达到 low 的水位线的时间 /proc/vmstat kswapd_low_wmark_hit_quickly

metrics:

node_vmstat_kswapd_low_wmark_hit_quickly{instance=~"$node:$port",job=~"$job"}

20. Memory Buddy Alloc

type: Graph
Unit: short
Label: Allocations

Htlb_buddy_alloc_fail - buddy 给 hugetlb 分配失败的次数 /proc/vmstat htlb_buddy_alloc_fail

metrics:

node_vmstat_htlb_buddy_alloc_fail{instance=~"$node:$port",job=~"$job"}

Htlb_buddy_alloc_success - buddy 给 hugetlb 分配成功的次数 /proc/vmstat htlb_buddy_alloc_success

metrics:

node_vmstat_htlb_buddy_alloc_success{instance=~"$node:$port",job=~"$job"}

21. Memory Numa Allocations

type: Graph
Unit: short
Label: Allocations

Numa_foreign - 计划使用其他节点内存但是却使用本地内存次数 /proc/vmstat numa_foreign

metrics:

irate(node_vmstat_numa_foreign{instance=~"$node:$port",job=~"$job"}[5m])

Numa_hit - 使用本节点内存次数 /proc/vmstat numa_hit

metrics:

irate(node_vmstat_numa_hit{instance=~"$node:$port",job=~"$job"}[5m])

Numa_interleave - 交叉分配使用的内存中使用本节点的内存次数 /proc/vmstat numa_interleave

metrics:

irate(node_vmstat_numa_interleave{instance=~"$node:$port",job=~"$job"}[5m])

Numa_local - 在本节点运行的程序使用本节点内存次数 /proc/vmstat numa_local

metrics:

irate(node_vmstat_numa_local{instance=~"$node:$port",job=~"$job"}[5m])

Numa_miss - 计划使用本节点内存而被调度到其他节点次数 /proc/vmstat numa_miss

metrics:

irate(node_vmstat_numa_miss{instance=~"$node:$port",job=~"$job"}[5m])

Numa_other - 在其他节点运行的程序使用本节点内存次数 /proc/vmstat numa_other

metrics:

irate(node_vmstat_numa_other{instance=~"$node:$port",job=~"$job"}[5m])

22. Memory Numa Page Migrations

type: Graph
Unit: short
Label: Pages

Numa_pages_migrated - NUMA page 数 /proc/vmstat numa_pages_migrated

metrics:

irate(node_vmstat_numa_pages_migrated{instance=~"$node:$port",job=~"$job"}[5m])

Pgmigrate_fail - 迁移失败的页面数 /proc/vmstat pgmigrate_fail

metrics:

irate(node_vmstat_pgmigrate_fail{instance=~"$node:$port",job=~"$job"}[5m])

Pgmigrate_success - 成功迁移的页面数 /proc/vmstat pgmigrate_success

metrics:

irate(node_vmstat_pgmigrate_success{instance=~"$node:$port",job=~"$job"}[5m])

23. Memory Numa Hints

type: Graph
Unit: short
Label: Hints

Numa_hint_faults - NUMA hint faults trapped

metrics:

irate(node_vmstat_numa_hint_faults{instance=~"$node:$port",job=~"$job"}[5m])

Numa_hint_faults_local - Hinting faults to local nodes

metrics:

irate(node_vmstat_numa_hint_faults_local{instance=~"$node:$port",job=~"$job"}[5m])

24. Memory Numa Table Updates

type: Graph
Unit: short
Label: Updates

Numa_pte_updates - NUMA page table entry updates

metrics:

irate(node_vmstat_numa_pte_updates{instance=~"$node:$port",job=~"$job"}[5m])

Numa_huge_pte_updates - NUMA huge page table entry updates

metrics:

irate(node_vmstat_numa_huge_pte_updates{instance=~"$node:$port",job=~"$job"}[5m])

25. Memory THP Splits

type: Graph
Unit: short
Label: Splits

Thp_split - 大型页面分割成多个常规页面 /proc/vmstat thp_split

metrics:

irate(node_vmstat_thp_split{instance=~"$node:$port",job=~"$job"}[5m])

26. Memory Workingset

type: Graph
Unit: short
Label: Counter

Workingset_activate - Page activations to form the working set

metrics:

irate(node_vmstat_workingset_activate{instance=~"$node:$port",job=~"$job"}[5m])

Workingset_nodereclaim - NUMA node working set page reclaims

metrics:

irate(node_vmstat_workingset_nodereclaim{instance=~"$node:$port",job=~"$job"}[5m])

Workingset_refault - Refaults of previously evicted pages

metrics:

irate(node_vmstat_workingset_refault{instance=~"$node:$port",job=~"$job"}[5m])

27. Memory THP Allocations

type: Graph
Unit: short
Label: Allocations

Thp_collapse_alloc - Transparent huge page collapse allocations

metrics:

irate(node_vmstat_thp_collapse_alloc{instance=~"$node:$port",job=~"$job"}[5m])

Thp_collapse_alloc_failed - Transparent huge page collapse allocation failures

metrics:

irate(node_vmstat_thp_collapse_alloc_failed{instance=~"$node:$port",job=~"$job"}[5m])

Thp_zero_page_alloc - Transparent huge page zeroed page allocations

metrics:

irate(node_vmstat_thp_zero_page_alloc{instance=~"$node:$port",job=~"$job"}[5m])

Thp_zero_page_alloc_failed - Transparent huge page zeroed page allocation failures

metrics:

irate(node_vmstat_thp_zero_page_alloc_failed{instance=~"$node:$port",job=~"$job"}[5m])

Thp_fault_alloc - Transparent huge page fault allocations

metrics:

irate(node_vmstat_thp_fault_alloc{instance=~"$node:$port",job=~"$job"}[5m])

Thp_fault_fallback - Transparent huge page fault fallbacks

metrics:

irate(node_vmstat_thp_fault_fallback{instance=~"$node:$port",job=~"$job"}[5m])

Memory Detail Vmstat Counters

1. Memory Page Active

type: Graph
Unit: short
Label: Pages

Active_anon - pages最近被使用过的匿名虚拟内存页 /proc/vmstat nr_active_anon

metrics:

node_vmstat_nr_active_anon{instance=~"$node:$port",job=~"$job"}

Active_file - 最近被使用过的文件虚拟内存页 /proc/vmstat nr_active_file

metrics:

node_vmstat_nr_active_file{instance=~"$node:$port",job=~"$job"}

2. Memory Page Reclaimed / Unreclaimed

type: Graph
Unit: short
Label: Pages

Reclaimable - 可回收的 slab 虚拟内存页 /proc/vmstat nr_slab_reclaimable

metrics:

node_vmstat_nr_slab_reclaimable{instance=~"$node:$port",job=~"$job"}

Unreclaimable - 不可回收的 slab 虚拟内存页 /proc/vmstat nr_slab_unreclaimable

metrics:

node_vmstat_nr_slab_unreclaimable{instance=~"$node:$port",job=~"$job"}

3. Memory Page Inactive

type: Graph
Unit: short
Label: Pages

Inactive_anon - 每个 NUMA node 的每个域中的长时间未被访问过的匿名内存页 /proc/vmstat nr_inactive_anon

metrics:

node_vmstat_nr_inactive_anon{instance=~"$node:$port",job=~"$job"}

Inactive_file - 每个 NUMA node 的每个域中的长时间未被访问过的与文件对应的内存页 /proc/vmstat nr_inactive_file

metrics:

node_vmstat_nr_inactive_file{instance=~"$node:$port",job=~"$job"}     

4. Memory Page Dirty / Bounce

type: Graph
Unit: short
Label: Pages

Dirty - 脏页数 /proc/vmstat nr_dirty

metrics:

node_vmstat_nr_dirty{instance=~"$node:$port",job=~"$job"}

Bounce - Bounce buffer 页面数 /proc/vmstat nr_bounce

metrics:

node_vmstat_nr_bounce{instance=~"$node:$port",job=~"$job"}

5. Memory Page Free / Written

type: Graph
Unit: short
Label: Pages

Free_pages - 空闲页数 /proc/vmstat nr_free_pages

metrics:

node_vmstat_nr_free_pages{instance=~"$node:$port",job=~"$job"}

Written - 每个 NUMA node 的每个域中写出的页面 /proc/vmstat nr_written

metrics:

node_vmstat_nr_written{instance=~"$node:$port",job=~"$job"}

6.Memory Page Shmem / Mapped

type: Graph
Unit: short
Label: Pages

Shmem - 共享内存页数 /proc/vmstat nr_shmem

metrics:

node_vmstat_nr_shmem{instance=~"$node:$port",job=~"$job"}

Mapped - 每个 NUMA node 的每个域 mapped 缓存页的页数 /proc/vmstat nr_mapped

metrics:

node_vmstat_nr_mapped{instance=~"$node:$port",job=~"$job"}

7.Memory Page Unevictable / MLock

type: Graph
Unit: short
Label: Pages

Unevictable - 不可回收的页数 /proc/vmstat nr_unevictable

metrics:

node_vmstat_nr_unevictable{instance=~"$node:$port",job=~"$job"}

Mlock - 被 mlock()系统调用锁定的页数 /proc/vmstat nr_mlock

metrics:

node_vmstat_nr_mlock{instance=~"$node:$port",job=~"$job"}

8.Memory Page Writeback

type: Graph
Unit: short
Label: Pages

Writeback - 回写页数 /proc/vmstat nr_writeback

metrics:

node_vmstat_nr_writeback{instance=~"$node:$port",job=~"$job"}

Writeback_temp - 临时回写页数 /proc/vmstat nr_writeback_temp

metrics:

node_vmstat_nr_writeback_temp{instance=~"$node:$port",job=~"$job"}

9.Memory Page Kernel_stack

type: Graph
Unit: short
Label: Pages

Kernel_stack - 内核栈的页数 /proc/vmstat nr_kernel_stack

metrics:

node_vmstat_nr_kernel_stack{instance=~"$node:$port",job=~"$job"}

10.Memory Page Dirty Threshold

type: Graph
Unit: short
Label: Pages

Dirty_background_threshold - 脏页后台回写阈值 /proc/vmstat nr_dirty_background_threshold

metrics:

node_vmstat_nr_dirty_background_threshold{instance=~"$node:$port",job=~"$job"}

Dirty_threshold - 脏页限制阈值 /proc/vmstat nr_dirty_threshold

metrics:

node_vmstat_nr_dirty_threshold{instance=~"$node:$port",job=~"$job"}

11.Memory Page File_pages

type: Graph
Unit: short
Label: Pages

File_pages - 每个 NUMA node 的每个域文件缓存页的页数 /proc/vmstat nr_file_pages

metrics:

node_vmstat_nr_file_pages{instance=~"$node:$port",job=~"$job"}

12.Memory Page Page_table_pages

type: Graph
Unit: short
Label: Pages

Page_table_pages - 每个 NUMA node 的每个域页面表的页数 /proc/vmstat nr_page_table_pages

metrics:

node_vmstat_nr_page_table_pages{instance=~"$node:$port",job=~"$job"}

13.Memory Page Unstable / Dirtied

type: Graph
Unit: short
Label: Pages

Unstable - 每个 NUMA node 的每个域中处于不稳定页面的页数 /proc/vmstat nr_unstable

metrics:

node_vmstat_nr_unstable{instance=~"$node:$port",job=~"$job"}

Dirtied - 每个 NUMA node 的每个域中进入脏页面的页数 /proc/vmstat nr_dirtied

metrics:

node_vmstat_nr_dirtied{instance=~"$node:$port",job=~"$job"}

14.Memory Page Isolated

type: Graph
Unit: short
Label: Pages

Isolated_anon - 每个 NUMA node 的每个域中隔离的匿名内存页面的页数 /proc/vmstat nr_isolated_anon

metrics:

node_vmstat_nr_isolated_anon{instance=~"$node:$port",job=~"$job"}

Isolated_file - 每个 NUMA node 的每个域中隔离的文件存储页面的页数 /proc/vmstat nr_isolated_file

metrics:

node_vmstat_nr_isolated_file{instance=~"$node:$port",job=~"$job"}

15.Memory Page Alloc_batch

type: Graph
Unit: short
Label: Pages

Alloc_batch - 每个 NUMA node 的每个域中由于内存不足分配给其他域的页面 /proc/vmstat nr_alloc_batch

metrics:

node_vmstat_nr_alloc_batch{instance=~"$node:$port",job=~"$job"}

16.Memory Page Misc

type: Graph
Unit: short
Label: Pages

Free_cma - 每个 NUMA node 的每个域中空闲的连续内存分配器页面 /proc/vmstat nr_free_cma

metrics:

node_vmstat_nr_free_cma{instance=~"$node:$port",job=~"$job"}

Vmscan_write - LRU 内存回收写入的页面 /proc/vmstat nr_vmscan_write

metrics:

node_vmstat_nr_vmscan_write{instance=~"$node:$port",job=~"$job"}

Immediate_reclaim - 每个 NUMA node 的每个域中当回写结束时优先回收的页面 /proc/vmstat nr_vmscan_immediate_reclaim

metrics:

node_vmstat_nr_vmscan_immediate_reclaim{instance=~"$node:$port",job=~"$job"}

17.Memory Page Anon

type: Graph
Unit: short
Label: Pages

Anon_pages - 每个 NUMA node 的每个域中匿名 mapped 缓存页 /proc/vmstat nr_anon_pages

metrics:

node_vmstat_nr_anon_pages{instance=~"$node:$port",job=~"$job"}

Anon_transparent_hugepages - 每个 NUMA node 的每个域中 THP(Transparent Huge Pages) /proc/vmstat nr_anon_transparent_hugepages

metrics:

node_vmstat_nr_anon_transparent_hugepages{instance=~"$node:$port",job=~"$job"}

System Detail

1. Context Switches / Interrupts

type: Graph
Unit: short
Label: Counter

Context switches - CPU 的 context switch 平均次数(5分钟内)

metrics:

irate(node_context_switches_total{instance=~"$node:$port",job=~"$job"}[5m])

Interrupts - 服务的平均中断总数(5分钟内)

metrics:

irate(node_intr_total{instance=~"$node:$port",job=~"$job"}[5m])

2. System Load

type: Graph
Unit: short
Label: Load

Load 1m - 系统1分钟内的平均负载

metrics:

node_load1{instance=~"$node:$port",job=~"$job"}

Load 5m - 系统5分钟内的平均负载

metrics:

node_load5{instance=~"$node:$port",job=~"$job"}

Load 15m - 系统15分钟内的平均负载

metrics:

node_load15{instance=~"$node:$port",job=~"$job"}

3. Interrupts Detail /proc/interrupts

type: Graph
Unit: short
Label: Counter

{{ type }} - {{ info }} - 当前系统的软中断列表和对应的中断号平均中断次数(5分钟内)

metrics:

irate(node_interrupts_total{instance=~"$node:$port",job=~"$job"}[5m])

4. File Descriptors

type: Graph
Unit: short
Label: Descriptors

Maximum open file descriptors - 最大打开文件描述符数

metrics:

process_max_fds{instance=~"$node:$port",job=~"$job"}

Open file descriptors - 打开文件描述符的数量

metrics:

process_open_fds{instance=~"$node:$port",job=~"$job"}

5. Entropy

type: Graph
Unit: short
Label: Entropy

Entropy available to random number generators

metrics:

node_entropy_available_bits{instance=~"$node:$port",job=~"$job"}

6. Processes State

type: Graph
Unit: short
Label: Processes

Processes blocked - 当前被阻塞的任务的数目 /proc/stat procs_blocked

metrics:

node_procs_blocked{instance=~"$node:$port",job=~"$job"}

Processes in runnable state - 当前运行队列的任务的数目 /proc/stat procs_running

metrics:

node_procs_running{instance=~"$node:$port",job=~"$job"}

7. Processes Forks

type: Graph
Unit: short
Label: Forks / sec

Processes forks second - 每秒创建的进程个数

metrics:

rate(node_forks_total{instance=~"$node:$port",job=~"$job"}[5m])

8. Processes Memory

type: Graph
Unit: bytes
Label: Bytes

进程占用的虚拟内存的大小:

metrics:

process_virtual_memory_bytes{instance=~"$node:$port",job=~"$job"}

进程常驻内存大小:

metrics:

process_resident_memory_bytes{instance=~"$node:$port",job=~"$job"}

9. Time Syncronized Status

type: Graph
Unit: short
Label: Counter

时钟是否与一个可靠的服务器同步:

metrics:

node_timex_sync_status{instance=~"$node:$port",job=~"$job"}

本地时钟调整频率:

metrics:

node_timex_frequency_adjustment_ratio{instance=~"$node:$port",job=~"$job"}

10. Time Syncronized Drift

type: Graph
Unit: seconds
Label: Seconds

估算误差(秒):

metrics:

node_timex_estimated_error_seconds{instance=~"$node:$port",job=~"$job"}

本地系统和参考时钟之间的时间偏移:

metrics:

node_timex_offset_seconds{instance=~"$node:$port",job=~"$job"}

最大误差(秒):

metrics:

node_timex_maxerror_seconds{instance=~"$node:$port",job=~"$job"}

11. Hardware temperature monitor 硬件的温度监控

type: Graph
Unit: Celsius(摄氏度)
Label: Temperature

{{ chip }} {{ sensor }} temp -

metrics:

node_hwmon_temp_celsius{instance=~"$node:$port",job=~"$job"}

{{ chip }} {{ sensor }} Critical Alarm

metrics:

node_hwmon_temp_crit_alarm_celsius{instance=~"$node:$port",job=~"$job"}

{{ chip }} {{ sensor }} Critical

metrics:

node_hwmon_temp_crit_celsius{instance=~"$node:$port",job=~"$job"}

{{ chip }} {{ sensor }} Critical Historical

metrics:

node_hwmon_temp_crit_hyst_celsius{instance=~"$node:$port",job=~"$job"}

{{ chip }} {{ sensor }} Max

metrics:

node_hwmon_temp_max_celsius{instance=~"$node:$port",job=~"$job"}

Disk Datail /proc/diskstats

1. Disk IOps Completed

type: Graph
Unit: I/O ops/sec(iops)
Label: IO read(-)/write(+)

{{device}} - Reads completed: 每个磁盘分区每秒读完成次数

metrics:

irate(node_disk_reads_completed_total{instance=~"$node:$port",job=~"$job"}[5m])

{{device}} - Writes completed: 每个磁盘分区每秒写完成次数

metrics:

irate(node_disk_writes_completed_total{instance=~"$node:$port",job=~"$job"}[5m])

2. Disk R/W Data

type: Graph
Unit: bytes/sec
Label: Bytes read(-)/write(+)

{{device}} - Read bytes 每个磁盘分区每秒读取的比特数

metrics:

irate(node_disk_read_bytes_total{instance=~"$node:$port",job=~"$job"}[5m])

{{device}} - Written bytes 每个磁盘分区每秒写入的比特数

metrics:

irate(node_disk_written_bytes_total{instance=~"$node:$port",job=~"$job"}[5m])

3. Disk R/W Time

type: Graph
Unit: Milliseconds(ms)
Label: Millisec. read(-)/write(+)

{{device}} - Read time ms 每个磁盘分区读花费的毫秒数

metrics:

irate(node_disk_read_time_seconds_total{instance=~"$node:$port",job=~"$job"}[5m])

{{device}} - Write time ms 每个磁盘分区写操作花费的毫秒数

metrics:

irate(node_disk_write_time_seconds_total{instance=~"$node:$port",job=~"$job"}[5m])

4. Disk IOs Weighted

type: Graph
Unit: Milliseconds(ms)
Label: Milliseconds

{{device}} - IO time weighted 每个磁盘分区输入/输出操作花费的加权毫秒数

metrics:

irate(node_disk_io_time_weighted_seconds_total{instance=~"$node:$port",job=~"$job"}[5m])

5. Disk R/W Merged

type: Graph
Unit: I/O ops/sec(iops)
Label: I/Os

{{device}} - Read merged 每个磁盘分区每秒合并读完成次数

metrics:

irate(node_disk_reads_merged_total{instance=~"$node:$port",job=~"$job"}[5m])

{{device}} - Write merged 每个磁盘分区每秒合并写完成次数

metrics:

irate(node_disk_writes_merged_total{instance=~"$node:$port",job=~"$job"}[5m])

6. Milliseconds Spent Doing I/Os

type: Graph
Unit: Milliseconds(ms)
Label: Milliseconds

{{device}} - IO time ms 每个磁盘分区输入/输出操作花费的毫秒数

metrics:

irate(node_disk_io_time_seconds_total{instance=~"$node:$port",job=~"$job"}[5m])

7. Disk IOs Current in Progress

type: Graph
Unit: I/O ops/sec(iops)
Label: I/Os

{{device}} - IO now 每个磁盘分区每秒正在处理的输入/输出请求数

metrics:

irate(node_disk_io_now{instance=~"$node:$port",job=~"$job"}[5m])

8. Open Error File

type: Graph
Unit: short
Label: Errors

Textfile scrape error (1 = true) 打开文件错误的个数

metrics:

 node_textfile_scrape_error{instance=~"$node:$port",job=~"$job"}

FileSystem Detail /proc/filesystems

1. Filesystem space available

type: Graph
Unit: bytes
Label: Bytes

{{mountpoint}} - 挂载的文件系统可用空间

metrics:

node_filesystem_avail_bytes{instance=~"$node:$port",job=~"$job",device!~'rootfs'}

{{mountpoint}} - 挂载的文件系统剩余空间

metrics:

node_filesystem_free_bytes{instance=~"$node:$port",job=~"$job",device!~'rootfs'}

{{mountpoint}} - 挂载的文件系统占用空间

metrics:

node_filesystem_size_bytes{instance=~"$node:$port",job=~"$job",device!~'rootfs'}

2. File Nodes Free

type: Graph
Unit: short
Label: File Nodes

{{mountpoint}} - 挂载的文件系统空闲的文件节点个数

metrics:

node_filesystem_files_free{instance=~"$node:$port",job=~"$job",device!~'rootfs'}

3. File Descriptor

type: Graph
Unit: short
Label: Files

最大打开文件描述符数:

metrics:

node_filefd_maximum{instance=~"$node:$port",job=~"$job"}

打开文件描述符数:

metrics:

node_filefd_allocated{instance=~"$node:$port",job=~"$job"}

4. File Nodes Size

type: Graph
Unit: short
Label: File Nodes

{{mountpoint}} - File nodes total:挂载的文件系统的文件节点大小

metrics:

node_filesystem_files{instance=~"$node:$port",job=~"$job",device!~'rootfs'}

5. Filesystem in ReadOnly

type: Graph
Unit: short
Label: Read Only

{{mountpoint}} - ReadOnly 只读模式挂载的文件系统

metrics:

node_filesystem_readonly{instance=~"$node:$port",job=~"$job",device!~'rootfs'}

Network Traffic Detail /proc/net/dev

1. Network Traffic by Packets

type: Graph
Unit: packets/sec
Label: Packets out (-) / in (+)

{{device}} - Receive 各个接口每秒接收的数据包总数

metrics:

irate(node_network_receive_packets_total{instance=~"$node:$port",job=~"$job"}[5m])

{{device}} - Transmit 各个接口每秒发送的数据包总数

metrics:

irate(node_network_transmit_packets_total{instance=~"$node:$port",job=~"$job"}[5m])

2. Network Traffic Errors

type: Graph
Unit: packets/sec
Label: Packets out (-) / in (+)

{{device}} - Receive errors 监测到各个接口每秒接收的错误数据包总数

metrics:

irate(node_network_receive_errs_total{instance=~"$node:$port",job=~"$job"}[5m])

{{device}} - Rransmit errors 监测到各个接口每秒发送的错误数据包总数

metrics:

irate(node_network_transmit_errs_total{instance=~"$node:$port",job=~"$job"}[5m])

3. Network Traffic Drop

type: Graph
Unit: packets/sec
Label: Packets out (-) / in (+)

{{device}} - Receive drop 各个接口每秒接收的丢弃的数据包总数

metrics:

irate(node_network_receive_drop_total{instance=~"$node:$port",job=~"$job"}[5m])

{{device}} - Transmit drop 各个接口每秒发送的丢弃的数据包总数

metrics:

irate(node_network_transmit_drop_total{instance=~"$node:$port",job=~"$job"}[5m])

4. Network Traffic Compressed

type: Graph
Unit: packets/sec
Label: Packets out (-) / in (+)

{{device}} - Receive compressed 各个接口每秒接收的压缩数据包总数

metrics:

irate(node_network_receive_compressed_total{instance=~"$node:$port",job=~"$job"}[5m])

{{device}} - Transmit compressed 各个接口每秒发送的压缩数据包总数

metrics:

irate(node_network_transmit_compressed_total{instance=~"$node:$port",job=~"$job"}[5m])

5. Network Traffic Multicast

type: Graph
Unit: packets/sec
Label: Packets out (-) / in (+)

{{device}} - Receive multicast 各个接口每秒接收的多播包数

metrics:

irate(node_network_receive_multicast_total{instance=~"$node:$port",job=~"$job"}[5m])

6. Network Traffic Fifo

type: Graph
Unit: packets/sec
Label: Packets out (-) / in (+)

{{device}} - Receive fifo 各个接口每秒接收的 fifo 包总数

metrics:

irate(node_network_receive_fifo_total{instance=~"$node:$port",job=~"$job"}[5m])

{{device}} - Transmit fifo 各个接口每秒发送的 fifo 包总数

metrics:

irate(node_network_transmit_fifo_total{instance=~"$node:$port",job=~"$job"}[5m])

7. Network Traffic Frame

type: Graph
Unit: packets/sec
Label: Packets out (-) / in (+)

{{device}} - Receive frame 各个接口每秒接收的帧数

metrics:

irate(node_network_receive_frame_total{instance=~"$node:$port",job=~"$job"}[5m])

8. Network Traffic Carrier

type: Graph
Unit: short
Label: Counter

{{device}} - Statistic transmit_carrier 由各个接口检测到的载波损耗的数量

metrics:

irate(node_network_transmit_carrier_total{instance=~"$node:$port",job=~"$job"}[5m])

9. Network Traffic Colls

type: Graph
Unit: short
Label: Counter

{{device}} - Transmit colls 各个接口上检测到的冲突数

metrics:

irate(node_network_transmit_colls_total{instance=~"$node:$port",job=~"$job"}[5m])

10. NF Contrack

type: Graph
Unit: short
Label: Entries

NF conntrack entries 跟踪连接数

metrics:

node_nf_conntrack_entries{instance=~"$node:$port",job=~"$job"}

NF conntrack limit

metrics:

node_nf_conntrack_entries_limit{instance=~"$node:$port",job=~"$job"}

11. ARP Entries

type: Graph
Unit: short
Label: Entries

{{ device }} - ARP entries 各个接口上 ARP 表中包的统计

metrics:

node_arp_entries{instance=~"$node:$port",job=~"$job"}

Network Sockstat proc/net/sockstat

1. Sockstat TCP

type: Graph
Unit: short
Label: Sockets

TCP_alloc - 已分配(已建立、已申请到sk_buff)的TCP套接字数量

metrics:

node_sockstat_TCP_alloc{instance=~"$node:$port",job=~"$job"}

TCP_inuse - 正在使用(正在侦听)的TCP套接字数量

metrics:

node_sockstat_TCP_inuse{instance=~"$node:$port",job=~"$job"}

TCP_mem - TCP 套接字缓冲区使用量

metrics:

node_sockstat_TCP_mem{instance=~"$node:$port",job=~"$job"}

TCP_orphan - 无主(不属于任何进程)的TCP连接数(无用、待销毁的TCP socket数)

metrics:

node_sockstat_TCP_orphan{instance=~"$node:$port",job=~"$job"}

TCP_tw - 等待关闭的TCP连接数

metrics:

node_sockstat_TCP_tw{instance=~"$node:$port",job=~"$job"}

2. Sockstat UDP

type: Graph
Unit: short
Label: Sockets

UDPLITE_inuse - 正在使用的 UDP-Lite 套接字数量

metrics:

node_sockstat_UDPLITE_inuse{instance=~"$node:$port",job=~"$job"}

UDP_inuse - 正在使用的 UDP 套接字数量

metrics:

node_sockstat_UDP_inuse{instance=~"$node:$port",job=~"$job"}

UDP_mem - UDP 套接字缓冲区使用量

metrics:

node_sockstat_UDP_mem{instance=~"$node:$port",job=~"$job"}

3. Sockstat Used

type: Graph
Unit: short
Label: Sockets

Sockets_used - 已使用的所有协议套接字总量

metrics:

node_sockstat_sockets_used{instance=~"$node:$port",job=~"$job"}

4. Sockstat Memory Size

type: Graph
Unit: bytes
Label: Bytes

TCP_mem_bytes - TCP 套接字缓冲区比特数

metrics:

node_sockstat_TCP_mem_bytes{instance=~"$node:$port",job=~"$job"}

UDP_mem_bytes - UDP 套接字缓冲区比特数

metrics:

node_sockstat_UDP_mem_bytes{instance=~"$node:$port",job=~"$job"}

5. Sockstat FRAG / RAW

type: Graph
Unit: short
Label: Sockets

FRAG_inuse - 正在使用的 Frag 套接字数量

metrics:

node_sockstat_FRAG_inuse{instance=~"$node:$port",job=~"$job"}

FRAG_memory - 使用的 Frag 缓冲区

metrics:

node_sockstat_FRAG_memory{instance=~"$node:$port",job=~"$job"}

RAW_inuse - 正在使用的 Raw 套接字数量

metrics:

node_sockstat_RAW_inuse{instance=~"$node:$port",job=~"$job"}

Network Netstat /proc/net/netstat

1. Netstat IP In / Out

type: Graph
Unit: short
Label: Datagrams out (-) / in (+)

InReceives - 接收到的 ip 数据报

metrics:

irate(node_netstat_Ip_InReceives{instance=~"$node:$port",job=~"$job"}[5m])

DefaultTTL - 接收的默认生存时间的 IP 数据报

metrics:

irate(node_netstat_Ip_DefaultTTL{instance=~"$node:$port",job=~"$job"}[5m])

InDelivers - 传递的 IP 数据报

metrics:

irate(node_netstat_Ip_InDelivers{instance=~"$node:$port",job=~"$job"}[5m])

OutRequests - 发送的 ip 数据报

metrics:

irate(node_netstat_Ip_OutRequests{instance=~"$node:$port",job=~"$job"}[5m])

2. Netstat IP In / Out

type: Graph
Unit: short
Label: Octets out (-) / in (+)

InOctets - 接收到的 ip 数据报(octets)

metrics:

irate(node_netstat_IpExt_InOctets{instance=~"$node:$port",job=~"$job"}[5m])

OutOctets - 发送的 ip 数据报(octets)

metrics:

irate(node_netstat_IpExt_OutOctets{instance=~"$node:$port",job=~"$job"}[5m])

3. Netstat IP Bcast

type: Graph
Unit: short
Label: Datagrams out (-) / in (+)

InBcastPkts - 接收的 IP 广播数据报报文

metrics:

irate(node_netstat_IpExt_InBcastPkts{instance=~"$node:$port",job=~"$job"}[5m])

OutBcastPkts - 发送的 IP 广播数据报报文

metrics:

irate(node_netstat_IpExt_OutBcastPkts{instance=~"$node:$port",job=~"$job"}[5m])

4. Netstat IP Bcast Octets

type: Graph
Unit: short
Label: Octets out (-) / in (+)

InBcastOctets - 接收的 IP 广播数据报 octet 数

metrics:

irate(node_netstat_IpExt_InBcastOctets{instance=~"$node:$port",job=~"$job"}[5m])

OutBcastOctets - 发送的 IP 广播数据报 octet 数

metrics:

irate(node_netstat_IpExt_OutBcastOctets{instance=~"$node:$port",job=~"$job"}[5m])

5. Netstat IP Mcast

type: Graph
Unit: short
Label: Datagrams out (-) / in (+)

InMcastPkts - 接收的 IP 多播数据报报文

metrics:

irate(node_netstat_IpExt_InMcastPkts{instance=~"$node:$port",job=~"$job"}[5m])

OutMcastPkts - 发送的 IP 多播数据报报文

metrics:

irate(node_netstat_IpExt_OutMcastPkts{instance=~"$node:$port",job=~"$job"}[5m])

6. Netstat IP Mcast Octets

type: Graph
Unit: short
Label: Octets out (-) / in (+)

InMcastOctets - 接收的 IP 多播数据报octet 数

metrics:

irate(node_netstat_IpExt_InMcastOctets{instance=~"$node:$port",job=~"$job"}[5m])

OutMcastOctets - 发送的 IP 多播数据报报文 octet 数

metrics:

irate(node_netstat_IpExt_OutMcastOctets{instance=~"$node:$port",job=~"$job"}[5m])

7. Netstat IP Forwarding

type: Graph
Unit: short
Label: Datagrams

ForwDatagrams - IP 转发报文数

metrics:

irate(node_netstat_Ip_ForwDatagrams{instance=~"$node:$port",job=~"$job"}[5m])

Forwarding - IP 转发

metrics:

irate(node_netstat_Ip_Forwarding{instance=~"$node:$port",job=~"$job"}[5m])

8. Netstat IP Fragmented

type: Graph
Unit: short
Label: Datagrams

FragCreates - 创建的 IP 分片报文数

metrics:

irate(node_netstat_Ip_FragCreates{instance=~"$node:$port",job=~"$job"}[5m])

FragFails - 失败的 IP 分片报文数

metrics:

irate(node_netstat_Ip_FragFails{instance=~"$node:$port",job=~"$job"}[5m])

FragOKs - 成功的 IP 分片报文数

metrics:

irate(node_netstat_Ip_FragOKs{instance=~"$node:$port",job=~"$job"}[5m])

9. Netstat IP ECT / CEP

type: Graph
Unit: short
Label: Datagrams

InCEPkts - 拥塞转发的数据报

metrics:

irate(node_netstat_IpExt_InCEPkts{instance=~"$node:$port",job=~"$job"}[5m])

InECT0Pkts - 接收到的带有 ECT(0) 代码点的 ip 数据报

metrics:

irate(node_netstat_IpExt_InECT0Pkts{instance=~"$node:$port",job=~"$job"}[5m])

InECT1Pkt - 接收到的带有 ECT(1) 代码点的 ip 数据报

metrics:

irate(node_netstat_IpExt_InECT1Pkts{instance=~"$node:$port",job=~"$job"}[5m])

InNoECTPkts - 接收到的带有 NOECT 的 ip 数据报

metrics:

irate(node_netstat_IpExt_InNoECTPkts{instance=~"$node:$port",job=~"$job"}[5m])

10. Netstat IP Reasambled

type: Graph
Unit: short
Label: Datagrams

ReasmFails - IP 重组失败的数据报

metrics:

irate(node_netstat_Ip_ReasmFails{instance=~"$node:$port",job=~"$job"}[5m])

ReasmOKs - IP 重组成功的数据报

metrics:

irate(node_netstat_Ip_ReasmOKs{instance=~"$node:$port",job=~"$job"}[5m])

ReasmReqds - 需要进行 IP 重组的数据报

metrics:

irate(node_netstat_Ip_ReasmReqds{instance=~"$node:$port",job=~"$job"}[5m])

ReasmTimeout - IP 重组超时的数据报

metrics:

irate(node_netstat_Ip_ReasmTimeout{instance=~"$node:$port",job=~"$job"}[5m])

11. Netstat IP Errors / Discards

type: Graph
Unit: short
Label: Datagrams out (-) / in (+)

InDiscards - 接收的丢弃的 ip 数据报

metrics:

irate(node_netstat_Ip_InDiscards{instance=~"$node:$port",job=~"$job"}[5m])

InHdrErrors - IP inhdrerrors

metrics:

irate(node_netstat_Ip_InHdrErrors{instance=~"$node:$port",job=~"$job"}[5m])

InUnknownProtos - 由于未知协议而丢弃的 IP 数据报

metrics:

irate(node_netstat_Ip_InUnknownProtos{instance=~"$node:$port",job=~"$job"}[5m])

OutDiscards - IP outdiscards

metrics:

irate(node_netstat_Ip_OutDiscards{instance=~"$node:$port",job=~"$job"}[5m])

OutNoRoutes - 由于没有输出路由而丢弃的 IP 数据报

metrics:

irate(node_netstat_Ip_OutNoRoutes{instance=~"$node:$port",job=~"$job"}[5m])

InNoRoutes - 由于转发路径中没有路由而丢弃的 IP 数据报

metrics:

irate(node_netstat_IpExt_InNoRoutes{instance=~"$node:$port",job=~"$job"}[5m])

InCsumErrors - 具有校验和错误的 IP 数据报

metrics:

irate(node_netstat_IpExt_InCsumErrors{instance=~"$node:$port",job=~"$job"}[5m])

InTruncatedPkts - 由于帧没有携带足够的数据而丢弃的 IP 数据报

metrics:

irate(node_netstat_IpExt_InTruncatedPkts{instance=~"$node:$port",job=~"$job"}[5m])

InAddrErrors - 由于内部地址错误而丢弃的 IP 数据报

metrics:

irate(node_netstat_Ip_InAddrErrors{instance=~"$node:$port",job=~"$job"}[5m])

Network Netstat TCP /proc/net/snmp

1. TCP Segments

type: Graph
Unit: short
Label: Segments out (-) / in (+)

InCsumErrors - 接收的带有校验和错误的报文数(5分钟内)

metrics:

irate(node_netstat_Tcp_InCsumErrors{instance=~"$node:$port",job=~"$job"}[5m])

InErrs - TCP 接收的错误报文数(5分钟内)(例如:错误的校验和)

metrics:

irate(node_netstat_Tcp_InErrs{instance=~"$node:$port",job=~"$job"}[5m])

InSegs - TCP 接收的目前所有建立连接的错误报文数(5分钟内)(例如:错误的校验和)

metrics:

irate(node_netstat_Tcp_InSegs{instance=~"$node:$port",job=~"$job"}[5m])

OutRsts - TCP 发送的报文数(5分钟内)(包括 RST flag)

metrics:

irate(node_netstat_Tcp_OutRsts{instance=~"$node:$port",job=~"$job"}[5m])

OutSegs - TCP 发送的报文数(5分钟内)(包括当前连接的段但是不包括重传的段)

metrics:

irate(node_netstat_Tcp_OutSegs{instance=~"$node:$port",job=~"$job"}[5m])

RetransSegs - TCP 重传报文数(5分钟内)

metrics:

irate(node_netstat_Tcp_RetransSegs{instance=~"$node:$port",job=~"$job"}[5m])

2. TCP Connections

type: Graph
Unit: short
Label: Connections

CurrEstab - 当前状态为 ESTABLISHED 或 CLOSE-WAIT 的 TCP 连接数

metrics:

node_netstat_Tcp_CurrEstab{instance=~"$node:$port",job=~"$job"}

MaxConn - 限制实体可以支持的 TCP 最大连接总数

metrics:

node_netstat_Tcp_MaxConn{instance=~"$node:$port",job=~"$job"}

3. TCP Retransmission

type: Graph
Unit: milliseconds
Label: Milliseconds

RtoAlgorithm - TCP 重传超时时间

metrics:

node_netstat_Tcp_RtoAlgorithm{instance=~"$node:$port",job=~"$job"}

RtoMax - TCP允许的重传超时的最大值,以毫秒为单位

metrics:

node_netstat_Tcp_RtoMax{instance=~"$node:$port",job=~"$job"}

RtoMin - TCP允许的重传超时的最小值,以毫秒为单位

metrics:

node_netstat_Tcp_RtoMin{instance=~"$node:$port",job=~"$job"}

4. TCP Segments

type: Graph
Unit: short
Label: Connections

ActiveOpens - 已从 CLOSED 状态直接转换到 SYN-SENT 状态的 TCP 平均连接数(5分钟内)

metrics:

irate(node_netstat_Tcp_ActiveOpens{instance=~"$node:$port",job=~"$job"}[5m])

AttemptFails - 从 SYN-SENT 和 SYN-RCVD 转换到 CLOSED 状态的 TCP 平均连接数(5分钟内)

metrics:

irate(node_netstat_Tcp_AttemptFails{instance=~"$node:$port",job=~"$job"}[5m])

EstabResets - 从 ESTABLISHED 状态或 CLOSE-WAIT 状态直接转换到 CLOSED 状态的 TCP 平均连接数(5分钟内)

metrics:

irate(node_netstat_Tcp_EstabResets{instance=~"$node:$port",job=~"$job"}[5m])

PassiveOpens - 已从 LISTEN 状态直接转换到 SYN-RCVD 状态的 TCP 平均连接数(5分钟内)

metrics:

irate(node_netstat_Tcp_PassiveOpens{instance=~"$node:$port",job=~"$job"}[5m])

Network Netstat TCP Linux MIPs

1. TCP Aborts / Tiemouts

type: Graph
Unit: short
Label: Connections

TCPAbortOnClose - 由于用户关闭中止的连接数

metrics:

irate(node_netstat_TcpExt_TCPAbortOnClose{instance=~"$node:$port",job=~"$job"}[5m])

TCPAbortOnData - 由于意外数据而中止的连接数

metrics:

irate(node_netstat_TcpExt_TCPAbortOnData{instance=~"$node:$port",job=~"$job"}[5m])

TCPAbortOnLinger - 关闭后,在徘徊状态中止的连接数

metrics:

irate(node_netstat_TcpExt_TCPAbortOnLinger{instance=~"$node:$port",job=~"$job"}[5m])

TCPAbortOnMemory - 连接到 socket 之前中止的连接数

metrics:

irate(node_netstat_TcpExt_TCPAbortOnMemory{instance=~"$node:$port",job=~"$job"}[5m])

TCPAbortOnTimeout - 由于超时中止的连接数

metrics:

irate(node_netstat_TcpExt_TCPAbortOnTimeout{instance=~"$node:$port",job=~"$job"}[5m])

TCPAbortFailed - 由于内存不足,连接中止但未发送RST的连接数

metrics:

irate(node_netstat_TcpExt_TCPAbortFailed{instance=~"$node:$port",job=~"$job"}[5m])

TCPTimeouts - 其他 TCP 连接超时的连接数

metrics:

irate(node_netstat_TcpExt_TCPTimeouts{instance=~"$node:$port",job=~"$job"}[5m])

2. TCP Delayed ACK

type: Graph
Unit: short
Label: Counter

DelayedACKLocked - 由于 socket 锁定 延时ACK 进一步延迟的数量

metrics:

irate(node_netstat_TcpExt_DelayedACKLocked{instance=~"$node:$port",job=~"$job"}[5m])

DelayedACKLost - 快速回复 ACK 模式被激活的数量

metrics:

irate(node_netstat_TcpExt_DelayedACKLost{instance=~"$node:$port",job=~"$job"}[5m])

DelayedACKs - 发送延迟 AC K的数量

metrics:

irate(node_netstat_TcpExt_DelayedACKs{instance=~"$node:$port",job=~"$job"}[5m])

3. TCP SynCookie / Challenge

type: Graph
Unit: short
Label: Counter out (-) / in (+)

SyncookiesFailed - 接收的无效的 SYN cookies 的数量

metrics:

irate(node_netstat_TcpExt_SyncookiesFailed{instance=~"$node:$port",job=~"$job"}[5m])

SyncookiesRecv - 接收的 SYN cookies 的数量

metrics:

irate(node_netstat_TcpExt_SyncookiesRecv{instance=~"$node:$port",job=~"$job"}[5m])

SyncookiesSent - 发送的 SYN cookies 的数量

metrics:

irate(node_netstat_TcpExt_SyncookiesSent{instance=~"$node:$port",job=~"$job"}[5m])

SynChallenge - 发送的 SYNChallenge 数量

metrics:

irate(node_netstat_TcpExt_TCPSYNChallenge{instance=~"$node:$port",job=~"$job"}[5m])

TCPChallengeACK - 发送的 Challenge ACK 数量

metrics:

irate(node_netstat_TcpExt_TCPChallengeACK{instance=~"$node:$port",job=~"$job"}[5m])

4. TCP LOSS

type: Graph
Unit: short
Label: Counter

TCPLossFailures - 处于 Loss 状态下的 TCP 包数量

metrics:

irate(node_netstat_TcpExt_TCPLossFailures{instance=~"$node:$port",job=~"$job"}[5m])

TCPLossProbeRecovery - 恢复的 TCP 丢失探测定时器的数量

metrics:

irate(node_netstat_TcpExt_TCPLossProbeRecovery{instance=~"$node:$port",job=~"$job"}[5m])

TCPLossProbes - 发送的 TCP 丢失探测定时器的数量

metrics:

irate(node_netstat_TcpExt_TCPLossProbes{instance=~"$node:$port",job=~"$job"}[5m])

TCPLossUndo - 在部分确认后,拥塞窗口没有缓慢启动而恢复的数量

metrics:

irate(node_netstat_TcpExt_TCPLossUndo{instance=~"$node:$port",job=~"$job"}[5m])

TCPLostRetransmit - TCP 包丢失重传的数量

metrics:

irate(node_netstat_TcpExt_TCPLostRetransmit{instance=~"$node:$port",job=~"$job"}[5m])

5. TCP DROPS

type: Graph
Unit: short
Label: Counter

ListenDrops - 监听队列连接丢弃数

metrics:

irate(node_netstat_TcpExt_ListenDrops{instance=~"$node:$port",job=~"$job"}[5m])

LockDroppedIcmps - 因 socket 锁定而丢弃的 ICMP 数据包数量

metrics:

irate(node_netstat_TcpExt_LockDroppedIcmps{instance=~"$node:$port",job=~"$job"}[5m])

TCPDeferAcceptDrop - 在 SYN_RECV 状态下由 socket 接收的丢弃的 ACK 帧

metrics:

irate(node_netstat_TcpExt_TCPDeferAcceptDrop{instance=~"$node:$port",job=~"$job"}[5m])

TCPBacklogDrop - 由于 socket 接收队列已满,丢弃的TCP数据包数量

metrics:

irate(node_netstat_TcpExt_TCPBacklogDrop{instance=~"$node:$port",job=~"$job"}[5m])

OutOfWindowIcmps - 由于 out-of-window 丢弃的 ICMP 包数量

metrics:

irate(node_netstat_TcpExt_OutOfWindowIcmps{instance=~"$node:$port",job=~"$job"}[5m])

TCPMinTTLDrop - 在 minTTL 条件下丢弃的 TCP数据包的数量

metrics:

irate(node_netstat_TcpExt_TCPMinTTLDrop{instance=~"$node:$port",job=~"$job"}[5m])

6. TCP Retrans

type: Graph
Unit: short
Label: Counter

TCPForwardRetrans - 使用 F-RTO 重新传输丢失的数据包的数量

metrics:

irate(node_netstat_TcpExt_TCPForwardRetrans{instance=~"$node:$port",job=~"$job"}[5m])

TCPSlowStartRetrans - 在慢启动后重传丢失的数据包数量

metrics:

irate(node_netstat_TcpExt_TCPSlowStartRetrans{instance=~"$node:$port",job=~"$job"}[5m])

TCPSynRetrans - SYN-SYN/ACK重传以分解 SYN 中的重传,快速/超时重传

metrics:

irate(node_netstat_TcpExt_TCPSynRetrans{instance=~"$node:$port",job=~"$job"}[5m])

TCPSpuriousRTOs - TCP 虚假 RTOs 数量

metrics:

irate(node_netstat_TcpExt_TCPSpuriousRTOs{instance=~"$node:$port",job=~"$job"}[5m])

TCPSpuriousRtxHostQueues - Times detected that the fast clone is not yet freed in tcp_transmit_skb()

metrics:

 irate(node_netstat_TcpExt_TCPSpuriousRtxHostQueues{instance=~"$node:$port",job=~"$job"}[5m])

TCPFullUndo - 重传 undoRetransmits that undid the CWND reduction

metrics:

irate(node_netstat_TcpExt_TCPFullUndo{instance=~"$node:$port",job=~"$job"}[5m])

TCPRetransFail - tcp_retransmit_skb() 调用失败的数量

metrics:

irate(node_netstat_TcpExt_TCPRetransFail{instance=~"$node:$port",job=~"$job"}[5m])

TCPPartialUndo - 使用 Hoe heuristic 部分恢复拥塞窗口

metrics:

irate(node_netstat_TcpExt_TCPPartialUndo{instance=~"$node:$port",job=~"$job"}[5m])

7. TCP Pruned

type: Graph
Unit: short
Label: Counter

PruneCalled - 由于 socket 缓冲区溢出而从接收队列中删除的数据包数量

metrics:

irate(node_netstat_TcpExt_PruneCalled{instance=~"$node:$port",job=~"$job"}[5m])

RcvPruned - 从接收队列中删除的数据包数量

metrics:

irate(node_netstat_TcpExt_RcvPruned{instance=~"$node:$port",job=~"$job"}[5m])

OfoPruned - 由于 socket 缓冲区溢出,从无序队列中删除的数据包数量

metrics:

irate(node_netstat_TcpExt_OfoPruned{instance=~"$node:$port",job=~"$job"}[5m])

8. TCP Direct Copy

type: Graph
Unit: short
Label: Counter

TCPDirectCopyFromBacklog - 接收的来自 accept queue 的数据包

metrics:

irate(node_netstat_TcpExt_TCPDirectCopyFromBacklog{instance=~"$node:$port",job=~"$job"}[5m])

TCPDirectCopyFromPrequeue - 接收的来自 TCP prequeue 的数据包

metrics:

irate(node_netstat_TcpExt_TCPDirectCopyFromPrequeue{instance=~"$node:$port",job=~"$job"}[5m])

9. TCP TimeWait

type: Graph
Unit: short
Label: Counter

TW - 在快速计时器中完成 TIME_WAITTCP 套接字

metrics:

irate(node_netstat_TcpExt_TW{instance=~"$node:$port",job=~"$job"}[5m])

TWKilled - 在慢速计时器中完成 TIME_WAITTCP 套接字

metrics:

irate(node_netstat_TcpExt_TWKilled{instance=~"$node:$port",job=~"$job"}[5m])

TWRecycled - 按时间戳回收的 TIME_WAIT 套接字

metrics:

irate(node_netstat_TcpExt_TWRecycled{instance=~"$node:$port",job=~"$job"}[5m])

TCPTimeWaitOverflow - 发生 TIME_WAIT 溢出的数量

metrics:

irate(node_netstat_TcpExt_TCPTimeWaitOverflow{instance=~"$node:$port",job=~"$job"}[5m])

10. TCP PAWS

type: Graph
Unit: short
Label: Counter

PAWSActive - 由于 TCP 时间戳PAWS而拒绝激活的连接数

metrics:

irate(node_netstat_TcpExt_PAWSActive{instance=~"$node:$port",job=~"$job"}[5m])

PAWSEstab - 由于 TCP 时间戳PAWS而拒绝建立连接的数据包数量

metrics:

irate(node_netstat_TcpExt_PAWSEstab{instance=~"$node:$port",job=~"$job"}[5m])

PAWSPassive - 由于 TCP 时间戳PAWS而被拒绝的被动连接数

metrics:

irate(node_netstat_TcpExt_PAWSPassive{instance=~"$node:$port",job=~"$job"}[5m])

11. TCP SACK

type: Graph
Unit: short
Label: Counter

TCPSackRecovery - 使用 Sack 恢复丢失的包

metrics:

irate(node_netstat_TcpExt_TCPSackRecovery{instance=~"$node:$port",job=~"$job"}[5m])
TCPSackRecoveryFail - 使用 Sack 恢复丢失的包失败

metrics:

irate(node_netstat_TcpExt_TCPSackRecoveryFail{instance=~"$node:$port",job=~"$job"}[5m])

TCPSackShiftFallback

metrics:

irate(node_netstat_TcpExt_TCPSackShiftFallback{instance=~"$node:$port",job=~"$job"}[5m])

TCPSackShifted

metrics:

irate(node_netstat_TcpExt_TCPSackShifted{instance=~"$node:$port",job=~"$job"}[5m])

TCPSackDiscard

metrics:

irate(node_netstat_TcpExt_TCPSACKDiscard{instance=~"$node:$port",job=~"$job"}[5m])

TCPSackFailures

metrics:

irate(node_netstat_TcpExt_TCPSackFailures{instance=~"$node:$port",job=~"$job"}[5m])

TCPSackMerged

metrics:

irate(node_netstat_TcpExt_TCPSackMerged{instance=~"$node:$port",job=~"$job"}[5m])
TCPSACKReneging

metrics:

irate(node_netstat_TcpExt_TCPSACKReneging{instance=~"$node:$port",job=~"$job"}[5m])

TCPSACKReorder

metrics:

irate(node_netstat_TcpExt_TCPSACKReorder{instance=~"$node:$port",job=~"$job"}[5m])

12. TCP DSACK

type: Graph
Unit: short
Label: Counter

TCPDSACKIgnoredOld - 在重新传输时丢弃具有重复 SACK 的数据包

metrics:

irate(node_netstat_TcpExt_TCPDSACKIgnoredOld{instance=~"$node:$port",job=~"$job"}[5m])

TCPDSACKOfoRecv - 接收到无序的 DSACK 数据包

metrics:

irate(node_netstat_TcpExt_TCPDSACKOfoRecv{instance=~"$node:$port",job=~"$job"}[5m])

TCPDSACKOfoSent - 发送的无序的 DSACK 数据包

metrics:

irate(node_netstat_TcpExt_TCPDSACKOfoSent{instance=~"$node:$port",job=~"$job"}[5m])

TCPDSACKOldSent - 发送的旧 DSACKs 数据包

metrics:

irate(node_netstat_TcpExt_TCPDSACKOldSent{instance=~"$node:$port",job=~"$job"}[5m])

TCPDSACKRecv - 接收的 DSACK 数据包

metrics:

irate(node_netstat_TcpExt_TCPDSACKRecv{instance=~"$node:$port",job=~"$job"}[5m])

TCPDSACKUndo

metrics:

irate(node_netstat_TcpExt_TCPDSACKUndo{instance=~"$node:$port",job=~"$job"}[5m])

TCPDSACKIgnoredNoUndo

metrics:

irate(node_netstat_TcpExt_TCPDSACKIgnoredNoUndo{instance=~"$node:$port",job=~"$job"}[5m])

13. TCP FastOpen / FastRetrans

type: Graph
Unit: short
Label: Counter

TCPFastOpenActive - 成功的出站 TFO 连接

metrics:

irate(node_netstat_TcpExt_TCPFastOpenActive{instance=~"$node:$port",job=~"$job"}[5m])

TCPFastOpenActiveFail - 收到的 SYN-ACK 数据包未确认 SYN 数据包中发送的数据,并导致无 SYN 数据的重传

metrics:

irate(node_netstat_TcpExt_TCPFastOpenActiveFail{instance=~"$node:$port",job=~"$job"}[5m])

TCPFastOpenCookieReqd - 请求设置 TFO 但没有 cookie 的入站 SYN 数据包

metrics:

irate(node_netstat_TcpExt_TCPFastOpenCookieReqd{instance=~"$node:$port",job=~"$job"}[5m])

TCPFastOpenListenOverflow - TFO 监听队列溢出

metrics:

irate(node_netstat_TcpExt_TCPFastOpenListenOverflow{instance=~"$node:$port",job=~"$job"}[5m])

TCPFastOpenPassive - 成功的入站 TFO 连接

metrics:

irate(node_netstat_TcpExt_TCPFastOpenPassive{instance=~"$node:$port",job=~"$job"}[5m])

TCPFastOpenPassiveFail - 带有TFO cookie 的无效的入站 SYN 数据包

metrics:

irate(node_netstat_TcpExt_TCPFastOpenPassiveFail{instance=~"$node:$port",job=~"$job"}[5m])

TCPFastRetrans - 丢失快速重传的数据包

metrics:

irate(node_netstat_TcpExt_TCPFastRetrans{instance=~"$node:$port",job=~"$job"}[5m])

14. TCP HP

type: Graph
Unit: short
Label: Counter

TCPHPAcks - 接收到的不包含数据的 Acks

metrics:

irate(node_netstat_TcpExt_TCPHPAcks{instance=~"$node:$port",job=~"$job"}[5m])

TCPHPHits - HP 数据包

metrics:

irate(node_netstat_TcpExt_TCPHPHits{instance=~"$node:$port",job=~"$job"}[5m])

TCPHPHitsToUser

metrics:

irate(node_netstat_TcpExt_TCPHPHitsToUser{instance=~"$node:$port",job=~"$job"}[5m])

15. TCP ZeroWindow

type: Graph
Unit: short
Label: Counter

TCPToZeroWindowAdv

metrics:

irate(node_netstat_TcpExt_TCPToZeroWindowAdv{instance=~"$node:$port",job=~"$job"}[5m])

TCPWantZeroWindowAdv

metrics:

irate(node_netstat_TcpExt_TCPWantZeroWindowAdv{instance=~"$node:$port",job=~"$job"}[5m])

TCPFromZeroWindowAdv

metrics:

irate(node_netstat_TcpExt_TCPFromZeroWindowAdv{instance=~"$node:$port",job=~"$job"}[5m])

16. TCP Reorder

type: Graph
Unit: short
Label: Counter

TCPFACKReorder - 如果在需要更新时判断支持FACK,使用 TCPFACKReorder 计数器

metrics:

irate(node_netstat_TcpExt_TCPFACKReorder{instance=~"$node:$port",job=~"$job"}[5m])

TCPTSReorder - 如果是被一个partial ack确认后需要更新reorder值,使用 TCPTSReorder 计数器

metrics:

irate(node_netstat_TcpExt_TCPTSReorder{instance=~"$node:$port",job=~"$job"}[5m])

17. TCP Reno

type: Graph
Unit: short
Label: Counter

TCPRenoFailures - reno 后快速重传超时的数量

metrics:

irate(node_netstat_TcpExt_TCPRenoFailures{instance=~"$node:$port",job=~"$job"}[5m])

TCPRenoRecovery

metrics:

irate(node_netstat_TcpExt_TCPRenoRecovery{instance=~"$node:$port",job=~"$job"}[5m])

TCPRenoRecoveryFail

metrics:

irate(node_netstat_TcpExt_TCPRenoRecoveryFail{instance=~"$node:$port",job=~"$job"}[5m])

TCPRenoReorder

metrics:

irate(node_netstat_TcpExt_TCPRenoReorder{instance=~"$node:$port",job=~"$job"}[5m])

18. TCP ReqQ

type: Graph
Unit: short
Label: Counter

TCPReqQFullDoCookies

metrics:

irate(node_netstat_TcpExt_TCPReqQFullDoCookies{instance=~"$node:$port",job=~"$job"}[5m])

TCPReqQFullDrop

metrics:

irate(node_netstat_TcpExt_TCPReqQFullDrop{instance=~"$node:$port",job=~"$job"}[5m])

19. TCP Out of order

type: Graph
Unit: short
Label: Counter

TCPOFODrop - 在 OFO 中排队但由于达到了 socket rcvbuf 限制而丢弃的数据包

metrics:

irate(node_netstat_TcpExt_TCPOFODrop{instance=~"$node:$port",job=~"$job"}[5m])

TCPOFOMerge - OFO 中与其他数据包合并的数据包

metrics:

irate(node_netstat_TcpExt_TCPOFOMerge{instance=~"$node:$port",job=~"$job"}[5m])

TCPOFOQueue - OFO 队列的数据包

metrics:

irate(node_netstat_TcpExt_TCPOFOQueue{instance=~"$node:$port",job=~"$job"}[5m])

20. TCP MD5

type: Graph
Unit: short
Label: Counter

TCPMD5NotFound - 希望收到带 MD5 选项的包,但是包里面没有 MD5 选项

metrics:

irate(node_netstat_TcpExt_TCPMD5NotFound{instance=~"$node:$port",job=~"$job"}[5m])

TCPMD5Unexpected - 不希望收到带 MD5 选项的包,但是包里面有 MD5 选项

metrics:

irate(node_netstat_TcpExt_TCPMD5Unexpected{instance=~"$node:$port",job=~"$job"}[5m])

21. TCP Prequeued

type: Graph
Unit: short
Label: Counter

TCPPrequeued

metrics:

irate(node_netstat_TcpExt_TCPPrequeued{instance=~"$node:$port",job=~"$job"}[5m])

TCPPrequeueDropped - prequeue 队列丢弃的数据包

metrics:

irate(node_netstat_TcpExt_TCPPrequeueDropped{instance=~"$node:$port",job=~"$job"}[5m])

22. TCP Rcv

type: Graph
Unit: short
Label: Counter

TCPRcvCoalesce - 在接收队列中崩溃的数据包

metrics:

irate(node_netstat_TcpExt_TCPRcvCoalesce{instance=~"$node:$port",job=~"$job"}[5m])

TCPRcvCollapsed - 由于低的 socket 缓冲区,在接收队列中崩溃的数据包

metrics:

irate(node_netstat_TcpExt_TCPRcvCollapsed{instance=~"$node:$port",job=~"$job"}[5m])

23. TCP Original Data

type: Graph
Unit: short
Label: Counter

TCPOrigDataSent - 带有原始数据的传出数据包

metrics:

irate(node_netstat_TcpExt_TCPOrigDataSent{instance=~"$node:$port",job=~"$job"}[5m])

24. TCP Filters

type: Graph
Unit: short
Label: Counter

ArpFilter - 过滤的 Arp 数据包

metrics:

irate(node_netstat_TcpExt_ArpFilter{instance=~"$node:$port",job=~"$job"}[5m])

IPReversePathFilter - 从非直连网络到达的数据包

metrics:

irate(node_netstat_TcpExt_IPReversePathFilter{instance=~"$node:$port",job=~"$job"}[5m])

25. TCP Pure ACK

type: Graph
Unit: short
Label: Counter

TCPPureAcks - 接收到不包含的数据负载的 ACKs

metrics:

irate(node_netstat_TcpExt_TCPPureAcks{instance=~"$node:$port",job=~"$job"}[5m])

26. TCP Auto Corking

type: Graph
Unit: short
Label: Counter

TCPAutoCorking - Tcp 自动闭塞

metrics:

irate(node_netstat_TcpExt_TCPAutoCorking{instance=~"$node:$port",job=~"$job"}[5m])

27. TCP Issues

type: Graph
Unit: short
Label: Counter

BusyPollRxPackets - 低延迟应用程序获取的数据包

metrics:

irate(node_netstat_TcpExt_BusyPollRxPackets{instance=~"$node:$port",job=~"$job"}[5m])

EmbryonicRsts - Resets received for embryonic SYN_RECV sockets

metrics:

irate(node_netstat_TcpExt_EmbryonicRsts{instance=~"$node:$port",job=~"$job"}[5m])

ListenOverflows - 监听 socket 的队列溢出

metrics:

irate(node_netstat_TcpExt_ListenOverflows{instance=~"$node:$port",job=~"$job"}[5m])

TCPSchedulerFailed

metrics:

irate(node_netstat_TcpExt_TCPSchedulerFailed{instance=~"$node:$port",job=~"$job"}[5m])

TCPMemoryPressures

metrics:

irate(node_netstat_TcpExt_TCPMemoryPressures{instance=~"$node:$port",job=~"$job"}[5m])

Network Netstat UDP /proc/net/snmp

1. UDP In / Out

type: Graph
Unit: short
Label: Datagrams out (-) / in (+)

InDatagrams - 平均接收的 UDP 数据包(5分钟内)

metrics:

irate(node_netstat_Udp_InDatagrams{instance=~"$node:$port",job=~"$job"}[5m])

OutDatagrams - 平均发送的 UDP 数据包(5分钟内)

metrics:

irate(node_netstat_Udp_OutDatagrams{instance=~"$node:$port",job=~"$job"}[5m])

2. UDP Errors

type: Graph
Unit: short
Label: Datagrams out (-) / in (+)

InCsumErrors - 具有校验和错误的 UDP 数据包的平均数(5分钟内)

metrics:

irate(node_netstat_Udp_InCsumErrors{instance=~"$node:$port",job=~"$job"}[5m])

InErrors - 本机端口未监听之外的其他原因引起的 UDP 入包无法送达(应用层)的平均数(5分钟内)

metrics:

irate(node_netstat_Udp_InErrors{instance=~"$node:$port",job=~"$job"}[5m])

RcvbufErrors - 接收缓冲区溢出的 UDP 包的平均数(5分钟内)

metrics:

irate(node_netstat_Udp_RcvbufErrors{instance=~"$node:$port",job=~"$job"}[5m])

SndbufErrors - 发送缓冲区溢出的 UDP 包的平均数(5分钟内)

metrics:

irate(node_netstat_Udp_SndbufErrors{instance=~"$node:$port",job=~"$job"}[5m])

NoPorts - 未知端口接收 UDP 数据包的平均数(5分钟内)

metrics:

irate(node_netstat_Udp_NoPorts{instance=~"$node:$port",job=~"$job"}[5m])

3. UDP Lite In / Out

type: Graph
Unit: short
Label: Datagrams out (-) / in (+)

InDatagrams - 平均接收的 UDP-Lite 数据包(5分钟内)

metrics:

irate(node_netstat_UdpLite_InDatagrams{instance=~"$node:$port",job=~"$job"}[5m])

OutDatagrams - 平均发送的 UDP-Lite 数据包(5分钟内)

metrics:

irate(node_netstat_UdpLite_OutDatagrams{instance=~"$node:$port",job=~"$job"}[5m])

4. UDP Lite Errors

type: Graph
Unit: short
Label: Datagrams out (-) / in (+)

InCsumErrors - 具有校验和错误的 UDP-Lite 数据包的平均数(5分钟内)

metrics:

irate(node_netstat_UdpLite_InCsumErrors{instance=~"$node:$port",job=~"$job"}[5m])

InErrors - 本机端口未监听之外的其他原因引起的 UDP-Lite 入包无法送达(应用层)的平均数(5分钟内)

metrics:

irate(node_netstat_UdpLite_InErrors{instance=~"$node:$port",job=~"$job"}[5m])

RcvbufErrors - 接收缓冲区溢出的 UDP-Lite 包的平均数(5分钟内)

metrics:

irate(node_netstat_UdpLite_RcvbufErrors{instance=~"$node:$port",job=~"$job"}[5m])

SndbufErrors - 发送缓冲区溢出的 UDP-Lite 包的平均数(5分钟内)

metrics:

irate(node_netstat_UdpLite_InErrors{instance=~"$node:$port",job=~"$job"}[5m])

NoPorts - 未知端口接收 UDP-Lite 数据包的平均数(5分钟内)

metrics:

irate(node_netstat_UdpLite_NoPorts{instance=~"$node:$port",job=~"$job"}[5m])

Network Netstat ICMP /proc/net/snmp

1. ICMP Errors 1

type: Graph
Unit: short
Label: Messages out (-) / in (+)

InErrors - 接收的 ICMP 错误的报文(例如ICMP校验和错误、长度错误等)

metrics:

irate(node_netstat_Icmp_InErrors{instance=~"$node:$port",job=~"$job"}[5m])

OutErrors - 由于 ICMP 错误未发送的报文(例如缺少缓存

metrics:

irate(node_netstat_Icmp_OutErrors{instance=~"$node:$port",job=~"$job"}[5m])

InDestUnreachs - 接收终点不可达的报文

metrics:

irate(node_netstat_Icmp_InDestUnreachs{instance=~"$node:$port",job=~"$job"}[5m])

OutDestUnreachs - 发送终点不可达的报文

metrics:

irate(node_netstat_Icmp_OutDestUnreachs{instance=~"$node:$port",job=~"$job"}[5m])

InType11 - 时间超时报文

metrics:

irate(node_netstat_IcmpMsg_InType11{instance=~"$node:$port",job=~"$job"}[5m])

. ICMP Errors 2

type: Graph
Unit: short
Label: Messages out (-) / in (+)

InCsumErrors - 具有校验和错误 ICMP 报文

metrics:

irate(node_netstat_Icmp_InCsumErrors{instance=~"$node:$port",job=~"$job"}[5m])

InTimeExcds - 接收时间超时报文

metrics:

irate(node_netstat_Icmp_InTimeExcds{instance=~"$node:$port",job=~"$job"}[5m])

OutTimeExcds - 发送时间超时报文

metrics:

irate(node_netstat_Icmp_OutTimeExcds{instance=~"$node:$port",job=~"$job"}[5m])

InParmProbs - 接收参数错误报文

metrics:

irate(node_netstat_Icmp_InParmProbs{instance=~"$node:$port",job=~"$job"}[5m])

OutParmProb - 发送参数错误报文

metrics:

irate(node_netstat_Icmp_OutParmProbs{instance=~"$node:$port",job=~"$job"}[5m])

InSrcQuenchs - 接收源点抑制报文

metrics:

irate(node_netstat_Icmp_InSrcQuenchs{instance=~"$node:$port",job=~"$job"}[5m])

OutSrcQuenchs - 发送源点抑制报文

metrics:

irate(node_netstat_Icmp_OutSrcQuenchs{instance=~"$node:$port",job=~"$job"}[5m])

3. ICMP In / Out - Messages / Redirects

type: Graph
Unit: short
Label: Messages out (-) / in (+)

InMsgs - 接收的报文数

metrics:

irate(node_netstat_Icmp_InMsgs{instance=~"$node:$port",job=~"$job"}[5m])

InRedirects - 接收的 ICMP 重定向报文

metrics:

irate(node_netstat_Icmp_InRedirects{instance=~"$node:$port",job=~"$job"}[5m])

OutMsgs - 发送的报文数

metrics:

irate(node_netstat_Icmp_OutMsgs{instance=~"$node:$port",job=~"$job"}[5m])

OutRedirects - 发送的 ICMP 重定向报文

metrics:

irate(node_netstat_Icmp_OutRedirects{instance=~"$node:$port",job=~"$job"}[5m])

4. ICMP Timestamps

type: Graph
Unit: short
Label: Messages out (-) / in (+)

InTimestampReps - 接收(应答)时间戳

metrics:

irate(node_netstat_Icmp_InTimestampReps{instance=~"$node:$port",job=~"$job"}[5m])

InTimestamps - 接收(请求)时间戳

metrics:

irate(node_netstat_Icmp_InTimestamps{instance=~"$node:$port",job=~"$job"}[5m])

utTimestampReps - 发送(应答)时间戳

metrics:

irate(node_netstat_Icmp_OutTimestampReps{instance=~"$node:$port",job=~"$job"}[5m])

OutTimestamps - 发送(请求)时间戳

metrics:

irate(node_netstat_Icmp_OutTimestamps{instance=~"$node:$port",job=~"$job"}[5m])

5. ICMP Echos

type: Graph
Unit: short
Label: Messages out (-) / in (+)

InEchoReps - 接收回显(应答)消息

metrics:

irate(node_netstat_Icmp_InEchoReps{instance=~"$node:$port",job=~"$job"}[5m])

InEchos - 接收回显(请求)消息

metrics:

irate(node_netstat_Icmp_InTimestamps{instance=~"$node:$port",job=~"$job"}[5m])

OutEchoReps - 发送回显(应答)消息

metrics:

irate(node_netstat_Icmp_OutEchoReps{instance=~"$node:$port",job=~"$job"}[5m])

OutEchos - 发送回显(请求)消息

metrics:

irate(node_netstat_Icmp_OutEchos{instance=~"$node:$port",job=~"$job"}[5m])

6. ICMP Masks

type: Graph
Unit: short
Label: Messages out (-) / in (+)

InAddrMaskReps - 接收地址掩码(应答)消息

metrics:

irate(node_netstat_Icmp_InAddrMaskReps{instance=~"$node:$port",job=~"$job"}[5m])

InAddrMasks - 接收地址掩码(请求)消息

metrics:

irate(node_netstat_Icmp_InAddrMasks{instance=~"$node:$port",job=~"$job"}[5m])

OutAddrMaskReps - 发送地址掩码(应答)消息

metrics:

irate(node_netstat_Icmp_OutAddrMaskReps{instance=~"$node:$port",job=~"$job"}[5m])

OutAddrMasks - 发送地址掩码(请求)消息

metrics:

irate(node_netstat_Icmp_OutAddrMasks{instance=~"$node:$port",job=~"$job"}[5m])

Node Exporter

1. Node Exporter Scrape Time

type: Graph
Unit: seconds
Label: Seconds

{{collector}} - 各个收集器持续时间

metrics:

node_scrape_collector_duration_seconds{instance=~"$node:$port",job=~"$job"}

2. Node Exporter Scrape Success

type: Graph
Unit: short
Label: Counter

{{collector}} - 各个收集器正常工作数量

metrics:

node_scrape_collector_success{instance=~"$node:$port",job=~"$job"}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342