metrics.go 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518
  1. // Copyright 2019 Yunion
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package cloudprovider
  15. import (
  16. "strings"
  17. "time"
  18. )
  19. type TResourceType string
  20. type TMetricType string
  21. func (key TMetricType) Name() string {
  22. if !strings.Contains(string(key), ".") {
  23. return string(key)
  24. }
  25. return string(key)[0:strings.Index(string(key), ".")]
  26. }
  27. func (key TMetricType) Key() string {
  28. if len(key) == 0 {
  29. return ""
  30. }
  31. first, last := 0, len(key)
  32. if strings.Contains(string(key), ",") {
  33. last = strings.Index(string(key), ",")
  34. }
  35. if strings.Contains(string(key), ".") {
  36. first = strings.LastIndex(string(key), ".") + 1
  37. }
  38. return string(key)[first:last]
  39. }
  40. const (
  41. METRIC_RESOURCE_TYPE_RDS TResourceType = "rds"
  42. METRIC_RESOURCE_TYPE_SERVER TResourceType = "server"
  43. METRIC_RESOURCE_TYPE_HOST TResourceType = "host"
  44. METRIC_RESOURCE_TYPE_REDIS TResourceType = "redis"
  45. METRIC_RESOURCE_TYPE_LB TResourceType = "lb"
  46. METRIC_RESOURCE_TYPE_BUCKET TResourceType = "bucket"
  47. METRIC_RESOURCE_TYPE_K8S TResourceType = "k8s"
  48. METRIC_RESOURCE_TYPE_STORAGE TResourceType = "storage"
  49. METRIC_RESOURCE_TYPE_WIRE TResourceType = "wire"
  50. METRIC_RESOURCE_TYPE_CLOUD_ACCOUNT TResourceType = "cloudaccount_balance"
  51. METRIC_RESOURCE_TYPE_MODELARTS_POOL TResourceType = "modelarts"
  52. METRIC_RESOURCE_TYPE_EIP TResourceType = "eip"
  53. )
  54. const (
  55. // RDS监控指标
  56. // RDS CPU利用率
  57. // 支持的平台: huawei, aliyun, apsara, azure, jdcloud, qcloud, aws, hcso
  58. // 仅azure的sqlserver支持group_by = database
  59. RDS_METRIC_TYPE_CPU_USAGE TMetricType = "rds_cpu.usage_active"
  60. // RDS 内存利用率
  61. // 支持平台: huawei, aliyun, apsara, azure, jdcloud, qcloud, hcso
  62. // 仅azure的sqlserver支持group_by = database
  63. RDS_METRIC_TYPE_MEM_USAGE TMetricType = "rds_mem.used_percent"
  64. // RDS 网络入流量
  65. // 支持平台: huawei, aliyun, apsara, azure, aws, jdcloud, qcloud, hcso
  66. // 仅azure的sqlserver支持group_by = database
  67. RDS_METRIC_TYPE_NET_BPS_RX TMetricType = "rds_netio.bps_recv"
  68. // RDS 网络出流量
  69. // 支持平台: huawei, aliyun, apsara, azure, aws, jdcloud, qcloud, hcso
  70. // 仅azure的sqlserver支持group_by = database
  71. RDS_METRIC_TYPE_NET_BPS_TX TMetricType = "rds_netio.bps_sent"
  72. // RDS磁盘使用率
  73. // 支持平台: huawei, aliyun, apsara, azure, jdcloud, qcloud, hcso
  74. // 仅azure的sqlserver支持group_by = database
  75. RDS_METRIC_TYPE_DISK_USAGE TMetricType = "rds_disk.used_percent"
  76. // RDS磁盘读取IO
  77. // 支持平台: huawei, hcso
  78. RDS_METRIC_TYPE_DISK_READ_BPS TMetricType = "rds_diskio.read_bps"
  79. // RDS磁盘写IO
  80. // 支持平台: huawei, hcso
  81. RDS_METRIC_TYPE_DISK_WRITE_BPS TMetricType = "rds_diskio.write_bps"
  82. // ---
  83. // 支持平台: azure
  84. RDS_METRIC_TYPE_DISK_IO_PERCENT TMetricType = "rds_diskio.used_percent"
  85. // RDS 连接数
  86. // 支持平台: huawei, aws, qcloud, hcso
  87. RDS_METRIC_TYPE_CONN_COUNT TMetricType = "rds_conn.used_count"
  88. // RDS 活跃连接数
  89. // 支持平台: azure
  90. RDS_METRIC_TYPE_CONN_ACTIVE TMetricType = "rds_conn.active_count"
  91. // 连接数使用率
  92. // 支持平台: aliyun, apsara, qcloud
  93. RDS_METRIC_TYPE_CONN_USAGE TMetricType = "rds_conn.used_percent"
  94. // 支持平台: azure
  95. // 失败连接数
  96. RDS_METRIC_TYPE_CONN_FAILED TMetricType = "rds_conn.failed_count"
  97. METRIC_TAG_DATABASE = "database"
  98. // RDS QPS(每秒查询数)
  99. // 支持平台: huawei, qcloud, aliyun, apsara, hcso
  100. RDS_METRIC_TYPE_QPS TMetricType = "rds_qps.query_qps"
  101. // RDS TPS
  102. // 支持平台: huawei, qcloud, hcso
  103. RDS_METRIC_TYPE_TPS TMetricType = "rds_tps.trans_qps"
  104. // RDS innodb读IO
  105. // 支持平台: huawei, qcloud, hcso
  106. RDS_METRIC_TYPE_INNODB_READ_BPS TMetricType = "rds_innodb.read_bps"
  107. // RDS innodb写IO
  108. // 支持平台 huawei, qcloud, hcso
  109. RDS_METRIC_TYPE_INNODB_WRITE_BPS TMetricType = "rds_innodb.write_bps"
  110. // 虚拟机CPU使用率
  111. // 支持平台: kvm, huawei, aliyun, apsara, azure, esxi, google, bingocloud, aws, jdcloud, ecloud, zstack, qcloud, volcengine, baidu, ctyun, oracle
  112. VM_METRIC_TYPE_CPU_USAGE TMetricType = "vm_cpu.usage_active"
  113. // 虚拟机内存使用率
  114. // 支持平台: kvm, aliyun, apsara, azure, esxi, bingocloud, jdcloud, ecloud, qcloud, volcengine, baidu, ctyun, oracle
  115. VM_METRIC_TYPE_MEM_USAGE TMetricType = "vm_mem.used_percent"
  116. // 虚拟机磁盘使用率
  117. // 支持平台: aliyun, apsara, jdcloud, azure, baidu, ctyun, huawei, hcso, volcengine, qcloud
  118. // 支持按盘符(group_by=device)平台: aliyun, apsara
  119. VM_METRIC_TYPE_DISK_USAGE TMetricType = "vm_disk.used_percent"
  120. // 虚拟机磁盘读速率
  121. // 支持平台: huawei, aliyun, apsara, azure, esxi, google, bingocloud, aws, jdcloud, ecloud, zstack, volcengine, ctyun, hcso, oracle
  122. VM_METRIC_TYPE_DISK_IO_READ_BPS TMetricType = "vm_diskio.read_bps"
  123. // 虚拟机磁盘写速率
  124. // 支持平台: huawei, aliyun, apsara, azure, esxi, google, bingocloud, aws, jdcloud, ecloud, zstack, volcengine, ctyun, hcso, oracle
  125. VM_METRIC_TYPE_DISK_IO_WRITE_BPS TMetricType = "vm_diskio.write_bps"
  126. // 虚拟机磁盘读IOPS
  127. // 支持平台: huawei, aliyun, apsara, azure, google, bingocloud, aws, jdcloud, ecloud, zstack, volcengine, ctyun, oracle
  128. VM_METRIC_TYPE_DISK_IO_READ_IOPS TMetricType = "vm_diskio.read_iops"
  129. // 虚拟机磁盘写IOPS
  130. // 支持平台: huawei, aliyun, apsara, azure, google, bingocloud, aws, jdcloud, ecloud, zstack, volcengine, ctyun, oracle
  131. VM_METRIC_TYPE_DISK_IO_WRITE_IOPS TMetricType = "vm_diskio.write_iops"
  132. // 虚拟机网络入速率
  133. // 支持平台: huawei, aliyun, apsara, azure, esxi, google, bingocloud, aws, jdcloud, ecloud, zstack, qcloud, volcengine, baidu, ctyun, hcso, oracle
  134. VM_METRIC_TYPE_NET_BPS_RX TMetricType = "vm_netio.bps_recv"
  135. // 虚拟机网络出速率
  136. // 支持平台: huawei, aliyun, apsara, azure, esxi, google, bingocloud, aws, jdcloud, ecloud, zstack, qcloud, volcengine, baidu, ctyun, hcso, oracle
  137. VM_METRIC_TYPE_NET_BPS_TX TMetricType = "vm_netio.bps_sent"
  138. // 虚拟机外网出带宽使用率
  139. // 支持平台: qcloud, aliyun
  140. VM_METRIC_TYPE_NET_OUT_BANDWIDTH_USAGE TMetricType = "vm_netio.out_bandwidth_usage"
  141. // 虚拟机TCP连接数
  142. // 支持平台: aliyun, apsara, volcengine
  143. VM_METRIC_TYPE_NET_TCP_CONNECTION TMetricType = "vm_netio.tcp_connections"
  144. // 虚拟机进程监控
  145. // 支持平台: aliyun, apsara
  146. VM_METRIC_TYPE_PROCESS_NUMBER = "vm_process.number"
  147. // 宿主机CPU使用率
  148. // 支持平台: esxi, bingocloud, zstack
  149. HOST_METRIC_TYPE_CPU_USAGE TMetricType = "cpu.usage_active"
  150. // 宿主机内存使用率
  151. // 支持平台: esxi, bingocloud, zstack
  152. HOST_METRIC_TYPE_MEM_USAGE TMetricType = "mem.used_percent"
  153. // 宿主机磁盘读速率
  154. // 支持平台: esxi, bingocloud, zstack
  155. HOST_METRIC_TYPE_DISK_IO_READ_BPS TMetricType = "diskio.read_bps"
  156. // 宿主机磁盘写速率
  157. // 支持平台: esxi, bingocloud, zstack
  158. HOST_METRIC_TYPE_DISK_IO_WRITE_BPS TMetricType = "diskio.write_bps"
  159. // 宿主机网络入速率
  160. // 支持平台: esxi, bingocloud, zstack
  161. HOST_METRIC_TYPE_NET_BPS_RX TMetricType = "net.bps_recv"
  162. // 宿主机网络出速率
  163. // 支持平台: esxi, bingocloud, zstack
  164. HOST_METRIC_TYPE_NET_BPS_TX TMetricType = "net.bps_sent"
  165. //宿主机磁盘读IOPS
  166. // 支持平台: bingocloud, zstack
  167. HOST_METRIC_TYPE_DISK_IO_READ_IOPS TMetricType = "diskio.read_iops"
  168. //宿主机磁盘写IOPS
  169. // 支持平台: bingocloud, zstack
  170. HOST_METRIC_TYPE_DISK_IO_WRITE_IOPS TMetricType = "diskio.write_iops"
  171. // 宿主机系统运行时间
  172. HOST_METRIC_TYPE_SYSTEM_UPTIME TMetricType = "system.uptime"
  173. // 宿主机负载1
  174. HOST_METRIC_TYPE_LOAD1_PCORE TMetricType = "system.load1_pcore"
  175. // 宿主机僵尸进程数
  176. HOST_METRIC_TYPE_PROCESSES_ZOMBIES TMetricType = "processes.zombies"
  177. // 宿主机进程总数
  178. HOST_METRIC_TYPE_PROCESSES_TOTAL TMetricType = "processes.total"
  179. // 宿主机磁盘使用率
  180. HOST_METRIC_TYPE_DISK_USAGE TMetricType = "disk.used_percent"
  181. // 宿主机内存可用量
  182. HOST_METRIC_TYPE_MEM_AVAILABLE TMetricType = "mem.available"
  183. // Redis CPU使用率
  184. // 支持平台: huawei, aliyun, azure, apsara, aws, qcloud
  185. REDIS_METRIC_TYPE_CPU_USAGE TMetricType = "dcs_cpu.usage_active"
  186. // Redis 内存使用率
  187. // 支持平台: huawei, aliyun, azure, apsara, qcloud
  188. REDIS_METRIC_TYPE_MEM_USAGE TMetricType = "dcs_mem.used_percent"
  189. // Redis 网络入速率
  190. // 支持平台: huawei, aliyun, apsara, qcloud
  191. REDIS_METRIC_TYPE_NET_BPS_RX TMetricType = "dcs_netio.bps_recv"
  192. // Redis 网络出速率
  193. // 支持平台: huawei, aliyun, apsara, qcloud
  194. REDIS_METRIC_TYPE_NET_BPS_TX TMetricType = "dcs_netio.bps_sent"
  195. // Redis 网络连接数
  196. // 支持平台: huawei, aliyun, apsara, azure, aws, qcloud
  197. REDIS_METRIC_TYPE_USED_CONN TMetricType = "dcs_conn.used_conn"
  198. // 每秒处理指令数
  199. // 支持平台: huawei, aliyun, apsara, azure, qcloud
  200. REDIS_METRIC_TYPE_OPT_SES TMetricType = "dcs_instantopt.opt_sec"
  201. // 命中key数量
  202. // 支持平台: huawei, aliyun, apsara, azure, qcloud
  203. REDIS_METRIC_TYPE_CACHE_KEYS TMetricType = "dcs_cachekeys.key_count"
  204. // Expired Key数量
  205. // 支持平台: huawei, aliyun, apsara, azure, aws, qcloud
  206. REDIS_METRIC_TYPE_CACHE_EXP_KEYS TMetricType = "dcs_cachekeys.expire_key_count"
  207. // 内存使用量
  208. // 支持平台: huawei, aliyun, azure, apsara, qcloud
  209. REDIS_METRIC_TYPE_DATA_MEM_USAGE TMetricType = "dcs_datamem.used_byte"
  210. // 支持平台: azure
  211. LB_METRIC_TYPE_SNAT_PORT TMetricType = "haproxy.used_snat_port"
  212. // 支持平台: azure
  213. LB_METRIC_TYPE_SNAT_CONN_COUNT TMetricType = "haproxy.snat_conn_count"
  214. // 入带宽速率
  215. // 支持平台: huawei, aliyun, apsara, hcso
  216. LB_METRIC_TYPE_NET_BPS_RX TMetricType = "haproxy.bin"
  217. // 出带宽速率
  218. // 支持平台: huawei, aliyun, apsara, hcso
  219. LB_METRIC_TYPE_NET_BPS_TX TMetricType = "haproxy.bout"
  220. // 入包速率
  221. // 支持平台: apsara
  222. LB_METRIC_TYPE_NET_PACKET_RX TMetricType = "haproxy.packet_rx"
  223. // 出包速率
  224. // 支持平台: apsara
  225. LB_METRIC_TYPE_NET_PACKET_TX TMetricType = "haproxy.packet_tx"
  226. // 非活跃连接数
  227. // 支持平台: apsara
  228. LB_METRIC_TYPE_NET_INACTIVE_CONNECTION = "haproxy.inactive_connection"
  229. // 活跃连接数
  230. // 支持平台: hcso
  231. LB_METRIC_TYPE_NET_ACTIVE_CONNECTION = "haproxy.active_connection"
  232. // 最大并发数
  233. // 支持平台: apsara, hcso
  234. LB_METRIC_TYPE_MAX_CONNECTION = "haproxy.max_connection"
  235. // 后端异常ECS实例个数
  236. // 支持平台: apsara
  237. LB_METRIC_TYPE_UNHEALTHY_SERVER_COUNT = "haproxy.unhealthy_server_count"
  238. // 状态码统计
  239. // 支持平台: huawei, aliyun, apsara
  240. LB_METRIC_TYPE_HRSP_COUNT TMetricType = "haproxy.hrsp_Nxx"
  241. // 入方向丢弃流量
  242. // 支持平台: aliyun, apsara
  243. LB_METRIC_TYPE_DROP_TRAFFIC_TX = "haproxy.drop_traffic_tx"
  244. // 出方向丢弃流量
  245. // 支持平台: aliyun, apsara
  246. LB_METRIC_TYPE_DROP_TRAFFIC_RX = "haproxy.drop_traffic_rx"
  247. // 入方向丢弃包数
  248. // 支持平台: aliyun, apsara
  249. LB_METRIC_TYPE_DROP_PACKET_TX = "haproxy.drop_packet_tx"
  250. // 出方向丢弃包数
  251. // 支持平台: aliyun, apsara
  252. LB_METRIC_TYPE_DROP_PACKET_RX = "haproxy.drop_packet_rx"
  253. // 对象存储出速率
  254. // 支持平台: huawei, aliyun, apsara
  255. BUCKET_METRIC_TYPE_NET_BPS_TX TMetricType = "oss_netio.bps_sent"
  256. // 对象存储入速率
  257. // 支持平台: huawei, aliyun, apsara
  258. BUCKET_METRIC_TYPE_NET_BPS_RX TMetricType = "oss_netio.bps_recv"
  259. // 请求延时
  260. // 支持平台: huawei, aliyun, apsara
  261. BUCKET_METRIC_TYPE_LATECY TMetricType = "oss_latency.req_late"
  262. // 总请求数量
  263. // 支持平台: huawei, aliyun, apsara, hcso
  264. BUCKET_METRYC_TYPE_REQ_COUNT TMetricType = "oss_req.req_count"
  265. // 服务端请求错误数量
  266. // 支持平台: aliyun, apsara, volcengine
  267. BUCKET_METRIC_TYPE_REQ_5XX_COUNT TMetricType = "oss_req.5xx_count"
  268. // 服务端请求错误数量
  269. // 支持平台: aliyun, apsara, volcengine
  270. BUCKET_METRIC_TYPE_REQ_4XX_COUNT TMetricType = "oss_req.4xx_count"
  271. // 重定向数量
  272. // 支持平台: aliyun, apsara, volcengine
  273. BUCKET_METRIC_TYPE_REQ_3XX_COUNT TMetricType = "oss_req.3xx_count"
  274. // 正常请求数量
  275. // 支持平台: aliyun, apsara, volcengine
  276. BUCKET_METRIC_TYPE_REQ_2XX_COUNT TMetricType = "oss_req.2xx_count"
  277. // 存储总容量(bit)
  278. // 支持平台: aliyun, apsara, volcengine
  279. BUCKET_METRIC_TYPE_STORAGE_SIZE = "oss_storage.size"
  280. METRIC_TAG_REQUST = "request"
  281. METRIC_TAG_REQUST_GET = "get"
  282. METRIC_TAG_REQUST_POST = "post"
  283. METRIC_TAG_REQUST_2XX = "2xx"
  284. METRIC_TAG_REQUST_3XX = "3xx"
  285. METRIC_TAG_REQUST_4XX = "4xx"
  286. METRIC_TAG_REQUST_5XX = "5xx"
  287. METRIC_TAG_NET_TYPE = "net_type"
  288. // 外网
  289. METRIC_TAG_NET_TYPE_INTERNET = "internet"
  290. // 内网
  291. METRIC_TAG_NET_TYPE_INTRANET = "intranet"
  292. METRIC_TAG_TYPE_DISK_TYPE = "disk_type"
  293. METRIC_TAG_TYPE_DISK_TYPE_EBS = "ebs"
  294. // 磁盘利用率
  295. METRIC_TAG_DEVICE = "device"
  296. // 进程名称
  297. METRIC_TAG_PROCESS_NAME = "process_name"
  298. // 状态
  299. METRIC_TAG_STATE = "state"
  300. METRIC_TAG_NODE = "node"
  301. // k8s节点CPU使用率
  302. // 支持平台: aliyun, azure, qcloud
  303. K8S_NODE_METRIC_TYPE_CPU_USAGE TMetricType = "k8s_node_cpu.usage_active"
  304. // k8s节点内存使用率
  305. // 支持平台: aliyun, azure, qcloud
  306. K8S_NODE_METRIC_TYPE_MEM_USAGE TMetricType = "k8s_node_mem.used_percent"
  307. K8S_NODE_METRIC_TYPE_DISK_USAGE TMetricType = "k8s_node_disk.used_percent"
  308. K8S_NODE_METRIC_TYPE_NET_BPS_RX TMetricType = "k8s_node_netio.bps_recv"
  309. K8S_NODE_METRIC_TYPE_NET_BPS_TX TMetricType = "k8s_node_netio.bps_sent"
  310. // modelarts专属资源池监控数据
  311. MODELARTS_POOL_METRIC_TYPE_CPU_USAGE TMetricType = "modelarts_pool_cpu.usage_percent"
  312. MODELARTS_POOL_METRIC_TYPE_MEM_USAGE TMetricType = "modelarts_pool_mem.usage_percent"
  313. MODELARTS_POOL_METRIC_TYPE_GPU_MEM_USAGE TMetricType = "modelarts_pool_gpu_mem.usage_percent"
  314. MODELARTS_POOL_METRIC_TYPE_GPU_UTIL TMetricType = "modelarts_pool_gpu_util.percent"
  315. MODELARTS_POOL_METRIC_TYPE_NPU_UTIL TMetricType = "modelarts_pool_npu_util.percent"
  316. MODELARTS_POOL_METRIC_TYPE_NPU_MEM_USAGE TMetricType = "modelarts_pool_npu_mem.usage_percent"
  317. //磁盘可用容量
  318. MODELARTS_POOL_METRIC_TYPE_DISK_AVAILABLE_CAPACITY TMetricType = "modelarts_pool_disk.available_capacity"
  319. MODELARTS_POOL_METRIC_TYPE_DISK_CAPACITY TMetricType = "modelarts_pool_disk.capacity"
  320. MODELARTS_POOL_METRIC_TYPE_DISK_USAGE TMetricType = "modelarts_pool_disk.usage_percent"
  321. WIRE_METRIC_TYPE_CPU_USAGE TMetricType = "wire_cpu.usage_percent"
  322. WIRE_METRIC_TYPE_MEM_USAGE TMetricType = "wire_mem.usage_percent"
  323. WIRE_METRIC_TYPE_NET_RT TMetricType = "wire_net.rt" // 响应时间ms
  324. WIRE_METRIC_TYPE_NET_UNREACHABLE_RATE TMetricType = "wire_net.unreachable_rate" // 不可达率
  325. // EIP入带宽
  326. // 支持平台: aliyun, apsara
  327. EIP_METRIC_TYPE_NET_BPS_RX TMetricType = "eip_net.bps_recv"
  328. // EIP出带宽
  329. // 支持平台: aliyun, apsara
  330. EIP_METRIC_TYPE_NET_BPS_TX TMetricType = "eip_net.bps_sent"
  331. // EIP 出方向限速丢包率
  332. // 支持平台: aliyun, apsara
  333. EIP_METRIC_TYPE_NET_DROP_SPEED_TX TMetricType = "eip_net.drop_speed_rx"
  334. )
  335. var (
  336. ALL_RDS_METRIC_TYPES = []TMetricType{
  337. RDS_METRIC_TYPE_CPU_USAGE,
  338. RDS_METRIC_TYPE_MEM_USAGE,
  339. RDS_METRIC_TYPE_NET_BPS_RX,
  340. RDS_METRIC_TYPE_NET_BPS_TX,
  341. RDS_METRIC_TYPE_DISK_USAGE,
  342. RDS_METRIC_TYPE_DISK_READ_BPS,
  343. RDS_METRIC_TYPE_DISK_WRITE_BPS,
  344. RDS_METRIC_TYPE_DISK_IO_PERCENT,
  345. RDS_METRIC_TYPE_CONN_COUNT,
  346. RDS_METRIC_TYPE_CONN_ACTIVE,
  347. RDS_METRIC_TYPE_CONN_USAGE,
  348. RDS_METRIC_TYPE_CONN_FAILED,
  349. RDS_METRIC_TYPE_QPS,
  350. RDS_METRIC_TYPE_TPS,
  351. RDS_METRIC_TYPE_INNODB_READ_BPS,
  352. RDS_METRIC_TYPE_INNODB_WRITE_BPS,
  353. }
  354. ALL_HOST_METRIC_TYPES = []TMetricType{
  355. HOST_METRIC_TYPE_CPU_USAGE,
  356. HOST_METRIC_TYPE_MEM_USAGE,
  357. HOST_METRIC_TYPE_DISK_IO_READ_BPS,
  358. HOST_METRIC_TYPE_DISK_IO_WRITE_BPS,
  359. HOST_METRIC_TYPE_NET_BPS_RX,
  360. HOST_METRIC_TYPE_NET_BPS_TX,
  361. HOST_METRIC_TYPE_SYSTEM_UPTIME,
  362. HOST_METRIC_TYPE_LOAD1_PCORE,
  363. HOST_METRIC_TYPE_PROCESSES_ZOMBIES,
  364. HOST_METRIC_TYPE_PROCESSES_TOTAL,
  365. HOST_METRIC_TYPE_DISK_USAGE,
  366. HOST_METRIC_TYPE_MEM_AVAILABLE,
  367. }
  368. ALL_VM_METRIC_TYPES = []TMetricType{
  369. VM_METRIC_TYPE_CPU_USAGE,
  370. VM_METRIC_TYPE_MEM_USAGE,
  371. VM_METRIC_TYPE_DISK_USAGE,
  372. VM_METRIC_TYPE_DISK_IO_READ_BPS,
  373. VM_METRIC_TYPE_DISK_IO_WRITE_BPS,
  374. VM_METRIC_TYPE_DISK_IO_READ_IOPS,
  375. VM_METRIC_TYPE_DISK_IO_WRITE_IOPS,
  376. VM_METRIC_TYPE_NET_BPS_RX,
  377. VM_METRIC_TYPE_NET_BPS_TX,
  378. VM_METRIC_TYPE_NET_OUT_BANDWIDTH_USAGE,
  379. VM_METRIC_TYPE_NET_TCP_CONNECTION,
  380. VM_METRIC_TYPE_PROCESS_NUMBER,
  381. }
  382. ALL_REDIS_METRIC_TYPES = []TMetricType{
  383. REDIS_METRIC_TYPE_CPU_USAGE,
  384. REDIS_METRIC_TYPE_MEM_USAGE,
  385. REDIS_METRIC_TYPE_NET_BPS_RX,
  386. REDIS_METRIC_TYPE_NET_BPS_TX,
  387. REDIS_METRIC_TYPE_USED_CONN,
  388. REDIS_METRIC_TYPE_OPT_SES,
  389. REDIS_METRIC_TYPE_CACHE_KEYS,
  390. REDIS_METRIC_TYPE_CACHE_EXP_KEYS,
  391. REDIS_METRIC_TYPE_DATA_MEM_USAGE,
  392. }
  393. ALL_LB_METRIC_TYPES = []TMetricType{
  394. LB_METRIC_TYPE_SNAT_PORT,
  395. LB_METRIC_TYPE_SNAT_CONN_COUNT,
  396. LB_METRIC_TYPE_NET_BPS_RX,
  397. LB_METRIC_TYPE_NET_BPS_TX,
  398. LB_METRIC_TYPE_HRSP_COUNT,
  399. LB_METRIC_TYPE_NET_PACKET_RX,
  400. LB_METRIC_TYPE_NET_PACKET_TX,
  401. LB_METRIC_TYPE_UNHEALTHY_SERVER_COUNT,
  402. LB_METRIC_TYPE_NET_INACTIVE_CONNECTION,
  403. LB_METRIC_TYPE_MAX_CONNECTION,
  404. LB_METRIC_TYPE_DROP_PACKET_RX,
  405. LB_METRIC_TYPE_DROP_PACKET_TX,
  406. LB_METRIC_TYPE_DROP_TRAFFIC_RX,
  407. LB_METRIC_TYPE_DROP_TRAFFIC_TX,
  408. }
  409. ALL_BUCKET_TYPES = []TMetricType{
  410. BUCKET_METRIC_TYPE_NET_BPS_TX,
  411. BUCKET_METRIC_TYPE_NET_BPS_RX,
  412. BUCKET_METRIC_TYPE_LATECY,
  413. BUCKET_METRYC_TYPE_REQ_COUNT,
  414. BUCKET_METRIC_TYPE_REQ_5XX_COUNT,
  415. BUCKET_METRIC_TYPE_REQ_4XX_COUNT,
  416. BUCKET_METRIC_TYPE_REQ_3XX_COUNT,
  417. BUCKET_METRIC_TYPE_REQ_2XX_COUNT,
  418. BUCKET_METRIC_TYPE_STORAGE_SIZE,
  419. }
  420. ALL_K8S_NODE_TYPES = []TMetricType{
  421. K8S_NODE_METRIC_TYPE_CPU_USAGE,
  422. K8S_NODE_METRIC_TYPE_MEM_USAGE,
  423. }
  424. ALL_EIP_TYPES = []TMetricType{
  425. EIP_METRIC_TYPE_NET_BPS_RX,
  426. EIP_METRIC_TYPE_NET_BPS_TX,
  427. EIP_METRIC_TYPE_NET_DROP_SPEED_TX,
  428. }
  429. )
  430. type MetricListOptions struct {
  431. ResourceType TResourceType
  432. MetricType TMetricType
  433. ResourceId string
  434. // batch metric pull for tencentcloud
  435. ResourceIds []string
  436. RegionExtId string
  437. StartTime time.Time
  438. EndTime time.Time
  439. OsType string
  440. Interval int
  441. // rds
  442. Engine string
  443. // azure 内存,磁盘使用率监控需要查询table storage,会产生额外的存储费用,默认关闭
  444. IsSupportAzureTableStorageMetric bool
  445. }
  446. type MetricValue struct {
  447. Timestamp time.Time
  448. Value float64
  449. Tags map[string]string
  450. }
  451. type MetricValues struct {
  452. Id string
  453. Unit string
  454. MetricType TMetricType
  455. Values []MetricValue
  456. }