监控指标采集
开启指标
Master
指标监听端口为服务端口,默认开启指标监控模块Blobstore
指标监听端口为服务端口,默认开启服务自定义监控指标项,公共指标项需要修改配置文件进行打开,可参考:其他模块
需要配置指标监听端口,默认关闭exporterPort
: 指标监听端口。consulAddr
: consul注册服务器地址。设置后, 可配合prometheus的自动发现机制实现CubeFS节点exporter的自动发现服务,若不设置,将不会启用consul自动注册服务。consulMeta
:consul 元数据配置。 非必填项, 在注册到consul时设置元数据信息。ipFilter
: 基于正则表达式的过滤器。 非必填项,默认为空。暴露给consul, 当机器存在多个ip时使用. 支持正向和反向过滤。enablePid
:是否上报partition id, 默认为false; 如果想在集群展示dp或者mp的信息, 可以配置为 true。
{
"exporterPort": 9505,
"consulAddr": "http://consul.prometheus-cfs.local",
"consulMeta": "k1=v1;k2=v2",
"ipFilter": "10.17.*",
"enablePid": "false"
}
请求服务对应指标监听接口可以获取到监控指标,如curl localhost:port/metrics
采集指标
对于Master
、MetaNode
、DataNode
、ObjectNode
而言,有两种方式实现指标采集:
- 配置prometheus的consul地址(或者是支持prometheus标准语法的consul地址),配置生效后prometheus会主动拉取监控指标
- 不配置consul地址,示例如下:
修改prometheus的yaml配置文件,添加采集指标源
# prometheus.yml
- job_name: 'cubefs01'
file_sd_configs:
- files: [ '/home/service/app/prometheus/cubefs01/*.yml' ]
refresh_interval: 10s
接入exporter,在上述配置目录下创建exporter文件,以master为例,创建master_exporter.yaml文件
# master_exporter.yaml
- targets: [ 'master1_ip:17010' ]
labels:
cluster: cubefs01
配置完成之后启动prometheus即可。
纠删码子系统(Blobstore)
相关服务暂时只支持上述第二种方式采集指标。
在github上编辑