# 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: elasticsearch
# The monitoring i18n name
name:
zh-CN: ElasticSearch
en-US: ElasticSearch
ja-JP: ElasticSearch
# The description and help of this monitoring type
help:
zh-CN: Hertzbeat 对 ElasticSearch 数据库监控通用指标进行测量监控。
您可以点击 “新建 ElasticSearch” 并进行配置,或者选择“更多操作”,导入已有配置。
en-US: Hertzbeat monitoring ElasticSearch through general performance metrics. You could click the "New ElasticSearch" button and proceed with the configuration or import an existing setup through the "More Actions" menu.
zh-TW: Hertzbeat 對 ElasticSearch 資料庫監控通用名額進行量測監控。
您可以點擊“新建ElasticSearch”並進行配寘,或者選擇“更多操作”,導入已有配寘。
ja-JP: HertzBeat は ElasticSearch データベースの一般的なパフォーマンスのメトリック監視します。
「新規 ElasticSearch」をクリックしてパラメタを設定した後、新規することができます。
helpLink:
zh-CN: https://hertzbeat.apache.org/zh-cn/docs/help/elasticsearch
en-US: https://hertzbeat.apache.org/docs/help/elasticsearch
# 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
ja-JP: 目標ホスト
# type-param field type(most mapping the html input type)
type: host
# required-true or false
required: true
# field-param field key
- field: port
# name-param field display i18n name
name:
zh-CN: 端口
en-US: Port
ja-JP: ポート
# type-param field type(most mapping the html input type)
type: number
# when type is number, range is required
range: '[0,65535]'
# required-true or false
required: true
# default value
defaultValue: 9200
# field-param field key
- field: timeout
# name-param field display i18n name
name:
zh-CN: 查询超时时间
en-US: Query Timeout
ja-JP: クエリタイムアウト
# type-param field type(most mapping the html input type)
type: number
# required-true or false
required: false
# hide param-true or false
hide: true
# default value
defaultValue: 6000
# field-param field key
- field: ssl
# name-param field display i18n name
name:
zh-CN: 启用HTTPS
en-US: SSL
ja-JP: SSL利用
# type-param field type(boolean mapping the html h tag)
type: boolean
# required-true or false
required: true
# field-param field key
- field: authType
# name-param field display i18n name
name:
zh-CN: 认证方式
en-US: Auth Type
ja-JP: 認証方法
# type-param field type(most mapping the html input tag)
type: radio
# required-true or false
required: false
# when type is radio checkbox, use option to show optional values {name1:value1,name2:value2}
options:
- label: Basic Auth
value: Basic Auth
- label: Digest Auth
value: Digest Auth
# field-param field key
- field: username
# name-param field display i18n name
name:
zh-CN: 用户名
en-US: Username
ja-JP: ユーザー名
# type-param field type(most mapping the html input type)
type: text
# when type is text, use limit to limit string length
limit: 50
# required-true or false
required: false
# field-param field key
- field: password
# name-param field display i18n name
name:
zh-CN: 密码
en-US: Password
ja-JP: パスワード
# type-param field type(most mapping the html input tag)
type: password
# required-true or false
required: false
# collect metrics config list
metrics:
# metrics - cpu
- name: health
i18n:
zh-CN: 集群健康状态
en-US: Cluster Health Status
ja-JP: クラスタ健全状態
# 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: cluster_name
type: 1
label: true
i18n:
zh-CN: 集群名称
en-US: Cluster Name
ja-JP: クラスタ名
- field: status
type: 1
i18n:
zh-CN: 集群状态
en-US: status
ja-JP: 状態
- field: nodes
type: 0
i18n:
zh-CN: 集群节点数
en-US: nodes
ja-JP: ノード数
- field: data_nodes
type: 0
i18n:
zh-CN: 数据节点数
en-US: Data Nodes
ja-JP: データノード数
- field: active_primary_shards
type: 0
i18n:
zh-CN: 主节点活跃分片数
en-US: Active Primary Shards
ja-JP: 主ノードの活動中シャーズ数
- field: active_shards
type: 0
i18n:
zh-CN: 活跃分片数
en-US: Active Shards
ja-JP: 活動中シャーズ数
- field: active_percentage
type: 0
unit: '%'
i18n:
zh-CN: 分片健康度(%)
en-US: Active Percentage
ja-JP: シャーズの健全率
- field: initializing_shards
type: 0
i18n:
zh-CN: 初始化分片数
en-US: Initializing Shards
ja-JP: 初期化シャーズ数
- field: unassigned_shards
type: 0
i18n:
zh-CN: 未分配分片数
en-US: Unassigned Shards
ja-JP: 未割り当てシャーズ数
# (optional)metrics field alias name, it is used as an alias field to map and convert the collected data and metrics field
aliasFields:
- cluster_name
- status
- number_of_nodes
- number_of_data_nodes
- active_primary_shards
- active_shards
- initializing_shards
- unassigned_shards
- active_shards_percent_as_number
# mapping and conversion expressions, use these and aliasField above to calculate metrics value
# eg: cores=core1+core2, usage=usage, waitTime=allTime-runningTime
calculates:
- cluster_name=cluster_name
- status=status
- nodes=number_of_nodes
- data_nodes=number_of_data_nodes
- active_primary_shards=active_primary_shards
- active_shards=active_shards
- active_percentage=active_shards_percent_as_number
- initializing_shards=initializing_shards
- unassigned_shards=unassigned_shards
# 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: /_cluster/health?pretty
# http method: GET POST PUT DELETE PATCH
method: GET
# if enabled https
ssl: ^_^ssl^_^
# http auth
authorization:
# http auth type: Basic Auth, Digest Auth, Bearer Token
type: ^_^authType^_^
basicAuthUsername: ^_^username^_^
basicAuthPassword: ^_^password^_^
digestAuthUsername: ^_^username^_^
digestAuthPassword: ^_^password^_^
# http response data parse type: default-hertzbeat rule, jsonpath-jsonpath script, website-for website monitoring, prometheus-prometheus exporter rule
parseType: default
- name: nodes
i18n:
zh-CN: 集群节点信息
en-US: Cluster Nodes
ja-JP: クラスタノード情報
priority: 1
fields:
- field: total
type: 0
i18n:
zh-CN: 节点数
en-US: total
ja-JP: ノード数
- field: successful
type: 0
i18n:
zh-CN: 在线节点数
en-US: successful
ja-JP: オンラインノード数
- field: failed
type: 0
i18n:
zh-CN: 离线节点数
en-US: failed
ja-JP: オフラインノード数
protocol: http
http:
host: ^_^host^_^
port: ^_^port^_^
url: /_nodes/stats
method: GET
ssl: ^_^ssl^_^
authorization:
type: ^_^authType^_^
basicAuthUsername: ^_^username^_^
basicAuthPassword: ^_^password^_^
digestAuthUsername: ^_^username^_^
digestAuthPassword: ^_^password^_^
# http response data parse type: default-hertzbeat rule, jsonpath-jsonpath script, website-for website monitoring, prometheus-prometheus exporter rule
parseType: jsonPath
# parse script when parse type is josnPath
parseScript: '$._nodes'
- name: nodes_detail
i18n:
zh-CN: 节点详细信息
en-US: Node Detail
ja-JP: ノード情報
priority: 2
fields:
- field: node_name
type: 1
label: true
i18n:
zh-CN: 节点名称
en-US: Node Name
ja-JP: ノード名
- field: ip
type: 1
i18n:
zh-CN: IP地址
en-US: IP Address
ja-JP: IP アドレス
- field: cpu_load_average
type: 0
i18n:
zh-CN: CPU平均负载
en-US: Cpu Load Average
ja-JP: CPUロードアベレージ
- field: cpu_percent
type: 0
unit: '%'
i18n:
zh-CN: CPU占用率
en-US: Cpu Percent
ja-JP: CPU使用率
- field: heap_used
type: 0
unit: MB
i18n:
zh-CN: 内存使用量(MB)
en-US: Heap Used
ja-JP: メモリ使用量(MB)
- field: heap_used_percent
type: 0
unit: '%'
i18n:
zh-CN: 内存使用率
en-US: Heap Used Percent
ja-JP: メモリ使用率
- field: heap_total
type: 1
unit: 'MB'
i18n:
zh-CN: 总内存(MB)
en-US: Heap Total
ja-JP: メモリ容量(MB)
- field: disk_free
type: 0
unit: 'GB'
i18n:
zh-CN: 磁盘剩余容量(GB)
en-US: Disk Free
ja-JP: 利用可能なディスク容量
- field: disk_total
type: 1
unit: 'GB'
i18n:
zh-CN: 磁盘总容量
en-US: Disk Total
ja-JP: ディスク容量
- field: disk_used_percent
type: 0
unit: '%'
i18n:
zh-CN: 磁盘使用率
en-US: Disk Used Percent
ja-JP: ディスク使用率
aliasFields:
- $.name
- $.ip
- $.os.cpu.load_average.1m
- $.os.load_average
- $.os.cpu_percent
- $.os.cpu.percent
- $.jvm.mem.heap_used_in_bytes
- $.jvm.mem.heap_used_percent
- $.jvm.mem.heap_max_in_bytes
- $.fs.total.free_in_bytes
- $.fs.total.total_in_bytes
calculates:
- node_name=$.name
- ip=$.ip
- cpu_load_average=$.os.cpu.load_average.1m!=null?$.os.cpu.load_average.1m:$.os.load_average
- cpu_percent=$.os.cpu.percent!=null?$.os.cpu.percent:$.os.cpu_percent
- heap_used=$.jvm.mem.heap_used_in_bytes
- heap_used_percent=$.jvm.mem.heap_used_percent
- heap_total=$.jvm.mem.heap_max_in_bytes
- disk_free=$.fs.total.free_in_bytes
- disk_total=$.fs.total.total_in_bytes
- disk_used_percent=(1-$.fs.total.free_in_bytes/$.fs.total.total_in_bytes)*100
units:
- heap_used=B->MB
- heap_total=B->MB
- disk_free=B->GB
- disk_total=B->GB
protocol: http
http:
host: ^_^host^_^
port: ^_^port^_^
url: /_nodes/stats
method: GET
ssl: ^_^ssl^_^
authorization:
type: ^_^authType^_^
basicAuthUsername: ^_^username^_^
basicAuthPassword: ^_^password^_^
digestAuthUsername: ^_^username^_^
digestAuthPassword: ^_^password^_^
parseType: jsonPath
parseScript: '$.nodes.*'