yijiusmile
2021-05-17 00c11e16ac27b31c8d29b3c64afa88082010c33e
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
groups:
  - name: example #定义规则组
    rules:
      - alert: InstanceDown  #定义报警名称
        expr: up == 0   #Promql语句,触发规则
        for: 1m            # 一分钟
        labels:       #标签定义报警的级别和主机
          name: instance
          severity: Critical
        annotations:  #注解
          summary: " {{ $labels.appname }}" #报警摘要,取报警信息的appname名称
          description: " 服务停止运行 "   #报警信息
          value: "{{ $value }}%"  # 当前报警状态值
  - name: Host
    rules:
      - alert: HostMemory Usage
        expr: (node_memory_MemTotal_bytes - (node_memory_MemFree_bytes + node_memory_Buffers_bytes + node_memory_Cached_bytes)) / node_memory_MemTotal_bytes * 100 >  80
        for: 1m
        labels:
          name: Memory
          severity: Warning
        annotations:
          summary: " {{ $labels.appname }} "
          description: "宿主机内存使用率超过80%."
          value: "{{ $value }}"
      - alert: HostCPU Usage
        expr: sum(avg without (cpu)(irate(node_cpu_seconds_total{mode!='idle'}[5m]))) by (instance,appname) > 0.65
        for: 1m
        labels:
          name: CPU
          severity: Warning
        annotations:
          summary: " {{ $labels.appname }} "
          description: "宿主机CPU使用率超过65%."
          value: "{{ $value }}"
      - alert: HostLoad
        expr: node_load5 > 4
        for: 1m
        labels:
          name: Load
          severity: Warning
        annotations:
          summary: "{{ $labels.appname }} "
          description: " 主机负载5分钟超过4."
          value: "{{ $value }}"
      - alert: HostFilesystem Usage
        expr: 1-(node_filesystem_free_bytes / node_filesystem_size_bytes) >  0.8
        for: 1m
        labels:
          name: Disk
          severity: Warning
        annotations:
          summary: " {{ $labels.appname }} "
          description: " 宿主机 [ {{ $labels.mountpoint }} ]分区使用超过80%."
          value: "{{ $value }}%"
      - alert: HostDiskio
        expr: irate(node_disk_writes_completed_total{job=~"Host"}[1m]) > 10
        for: 1m
        labels:
          name: Diskio
          severity: Warning
        annotations:
          summary: " {{ $labels.appname }} "
          description: " 宿主机 [{{ $labels.device }}]磁盘1分钟平均写入IO负载较高."
          value: "{{ $value }}iops"
      - alert: Network_receive
        expr: irate(node_network_receive_bytes_total{device!~"lo|bond[0-9]|cbr[0-9]|veth.*|virbr.*|ovs-system"}[5m]) / 1048576  > 3
        for: 1m
        labels:
          name: Network_receive
          severity: Warning
        annotations:
          summary: " {{ $labels.appname }} "
          description: " 宿主机 [{{ $labels.device }}] 网卡5分钟平均接收流量超过3Mbps."
          value: "{{ $value }}3Mbps"
      - alert: Network_transmit
        expr: irate(node_network_transmit_bytes_total{device!~"lo|bond[0-9]|cbr[0-9]|veth.*|virbr.*|ovs-system"}[5m]) / 1048576  > 3
        for: 1m
        labels:
          name: Network_transmit
          severity: Warning
        annotations:
          summary: " {{ $labels.appname }} "
          description: " 宿主机 [{{ $labels.device }}] 网卡5分钟内平均发送流量超过3Mbps."
          value: "{{ $value }}3Mbps"
  - name: Container
    rules:
      - alert: ContainerCPU Usage
        expr: (sum by(name,instance) (rate(container_cpu_usage_seconds_total{image!=""}[5m]))*100) > 60
        for: 1m
        labels:
          name: CPU
          severity: Warning
        annotations:
          summary: "{{ $labels.name }} "
          description: " 容器CPU使用超过60%."
          value: "{{ $value }}%"
      - alert: ContainerMem Usage
        #    expr: (container_memory_usage_bytes - container_memory_cache)  / container_spec_memory_limit_bytes   * 100 > 10
        expr:  container_memory_usage_bytes{name=~".+"}  / 1048576 > 1024
        for: 1m
        labels:
          name: Memory
          severity: Warning
        annotations:
          summary: "{{ $labels.name }} "
          description: " 容器内存使用超过1GB."
          value: "{{ $value }}G"