# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You under the Apache License, Version 2.0
# (the "License"); you may not use this file except in compliance with
# the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# The monitoring type category:service-application service monitoring db-database monitoring custom-custom monitoring os-operating system monitoring
category: bigdata
# The monitoring type eg: linux windows tomcat mysql aws...
app: iotdb
# The monitoring i18n name
name:
zh-CN: Apache IoTDB
en-US: Apache IoTDB
# The description and help of this monitoring type
help:
zh-CN: HertzBeat 对 Apache IoTDB JVM相关的物联网时序数据库的运行状态,内存任务集群等相关指标(cluster node status、jvm memory committed bytes、jvm memory used bytes、jvm threads states threads、quantity、cache hit、queue、hrift connections) 进行监控。
⚠️注意:您需要在 IoTDB 开启 prometheus exporter metrics 接口,点击查看开启步骤。
en-US: HertzBeat monitoring the Apache IoTDB metrics such as operational status, memory, task, clusters, jvm etc.
⚠️Note:You should enable the prometheus metrics api in IoTDB. Click here to view the specific steps."
zh-TW: HertzBeat 對 Apache IoTDB JVM相關的物聯網時序數據庫的運行狀態,內存任務集群等相關指標(cluster node status、jvm memory committed bytes、jvm memory used bytes、jvm threads states threads、quantity、cache hit、queue、hrift connections) 進行監控。
⚠️注意:您需要在 IoTDB 開啓 prometheus exporter metrics 接口,點擊查看開啓步驟。
helpLink:
zh-CN: https://hertzbeat.apache.org/zh-cn/docs/help/iotdb/
en-US: https://hertzbeat.apache.org/docs/help/iotdb/
# Input params define for monitoring(render web ui by the definition)
params:
# field-param field key
- field: host
# name-param field display i18n name
name:
zh-CN: 目标Host
en-US: Target Host
# type-param field type(most mapping the html input type)
type: host
# required-true or false
required: true
- field: port
name:
zh-CN: 端口
en-US: Port
# type-param field type(most mapping the html input type)
type: number
# when type is number, range is required
range: '[0,65535]'
# default value
defaultValue: 9091
required: true
- field: timeout
name:
zh-CN: 查询超时时间
en-US: Query Timeout
type: number
required: false
# hide param-true or false
hide: true
defaultValue: 6000
# collect metrics config list
metrics:
# metrics - cluster_node_status
- name: cluster_node_status
i18n:
zh-CN: 集群节点状态
en-US: Cluster Node Status
# metrics scheduling priority(0->127)->(high->low), metrics with the same priority will be scheduled in parallel
# priority 0's metrics is availability metrics, it will be scheduled first, only availability metrics collect success will the scheduling continue
priority: 0
# collect metrics content
fields:
# field-metric name, type-metric type(0-number,1-string), unit-metric unit('%','ms','MB'), label-whether it is a metrics label field
- field: name
i18n:
zh-CN: 名称
en-US: name
type: 1
label: true
- field: status
i18n:
zh-CN: 状态
en-US: status
type: 0
# (optional)metrics field alias name, it is used as an alias field to map and convert the collected data and metrics field
aliasFields:
- name
- value
# mapping and conversion expressions, use these and aliasField above to calculate metrics value
# eg: cores=core1+core2, usage=usage, waitTime=allTime-runningTime
calculates:
- name=name
- status=value
# the protocol used for monitoring, eg: sql, ssh, http, telnet, wmi, snmp, sdk
protocol: http
# the config content when protocol is http
http:
# http host: ipv4 ipv6 domain
host: ^_^host^_^
# http port
port: ^_^port^_^
# http url
url: '/metrics'
timeout: ^_^timeout^_^
# http method: GET POST PUT DELETE PATCH
method: GET
# http response data parse type: default-hertzbeat rule, jsonpath-jsonpath script, website-for website monitoring, prometheus-prometheus exporter rule
parseType: prometheus
- name: jvm_memory_committed_bytes
i18n:
zh-CN: JVM内存已提交
en-US: JVM memory committed bytes
priority: 1
fields:
- field: area
i18n:
zh-CN: 区域
en-US: Area
type: 1
- field: id
i18n:
zh-CN: 内存块Id
en-US: Memory Block Id
type: 1
label: true
- field: value
i18n:
zh-CN: JVM请求内存大小(当前)
en-US: JVM requests memory size (current)
type: 0
unit: MB
units:
- value=B->MB
protocol: http
http:
host: ^_^host^_^
port: ^_^port^_^
url: '/metrics'
timeout: ^_^timeout^_^
method: GET
parseType: prometheus
- name: jvm_memory_used_bytes
i18n:
zh-CN: JVM内存已使用
en-US: JVM memory used bytes
priority: 2
fields:
- field: area
i18n:
zh-CN: 区域
en-US: Area
type: 1
- field: id
i18n:
zh-CN: 内存块Id
en-US: Memory Block Id
type: 1
label: true
- field: value
i18n:
zh-CN: JVM已使用内存大小
en-US: JVM used memory size
type: 0
unit: MB
units:
- value=B->MB
protocol: http
http:
host: ^_^host^_^
port: ^_^port^_^
url: '/metrics'
timeout: ^_^timeout^_^
method: GET
parseType: prometheus
- name: jvm_threads_states_threads
i18n:
zh-CN: JVM线程状态
en-US: JVM thread state
priority: 3
fields:
- field: state
i18n:
zh-CN: 线程状态
en-US: thread state
type: 1
label: true
- field: count
i18n:
zh-CN: 线程数量
en-US: thread count
type: 0
aliasFields:
- state
- value
calculates:
- count=value
protocol: http
http:
host: ^_^host^_^
port: ^_^port^_^
url: '/metrics'
timeout: ^_^timeout^_^
method: GET
parseType: prometheus
- name: quantity
i18n:
zh-CN: 数量
en-US: Quantity
priority: 4
fields:
- field: id
i18n:
zh-CN: Id
en-US: Id
type: 1
label: true
- field: name
i18n:
zh-CN: 名称
en-US: Name
type: 1
- field: type
i18n:
zh-CN: 类型
en-US: Type
type: 1
- field: value
i18n:
zh-CN: 值
en-US: Value
type: 0
aliasFields:
- name
- type
- value
calculates:
- id=name+"-"+type
protocol: http
http:
host: ^_^host^_^
port: ^_^port^_^
url: '/metrics'
timeout: ^_^timeout^_^
method: GET
parseType: prometheus
- name: cache_hit
i18n:
zh-CN: 缓存命中率
en-US: Cache hit rate
priority: 5
fields:
- field: name
i18n:
zh-CN: 名称
en-US: Name
type: 1
label: true
- field: value
i18n:
zh-CN: 命中率
en-US: Hit rate
type: 0
protocol: http
http:
host: ^_^host^_^
port: ^_^port^_^
url: '/metrics'
timeout: ^_^timeout^_^
method: GET
parseType: prometheus
- name: queue
i18n:
zh-CN: 队列
en-US: Queue
priority: 6
fields:
- field: id
i18n:
zh-CN: ID
en-US: ID
type: 1
label: true
- field: name
i18n:
zh-CN: 队列名称
en-US: Queue name
type: 1
- field: status
i18n:
zh-CN: 状态
en-US: Status
type: 1
- field: value
i18n:
zh-CN: 当前队列任务数量
en-US: Number of tasks in queue
type: 0
aliasFields:
- name
- status
- value
calculates:
- id=name+"-"+status
protocol: http
http:
host: ^_^host^_^
port: ^_^port^_^
url: '/metrics'
timeout: ^_^timeout^_^
method: GET
parseType: prometheus
- name: thrift_connections
i18n:
zh-CN: Thrift连接数
en-US: Thrift connection number
priority: 7
fields:
- field: name
i18n:
zh-CN: 连接名称
en-US: Connection name
type: 1
label: true
- field: connection
i18n:
zh-CN: 连接数
en-US: Connection number
type: 0
aliasFields:
- name
- value
calculates:
- connection=value
protocol: http
http:
host: ^_^host^_^
port: ^_^port^_^
url: '/metrics'
timeout: ^_^timeout^_^
method: GET
parseType: prometheus