原创

prometheus监控进程数据-process-export

温馨提示:
本文最后更新于 2023年05月11日,已超过 497 天没有更新。若文章内的图片失效(无法正常加载),请留言反馈或直接联系我

process-exporter是一个进程监控软件,可以把数据传输给prometheus进行管理

安装运行

地址:https://github.com/ncabatoff/process-exporter/releases

wget https://github.com/ncabatoff/process-exporter/releases/download/v0.7.10/process-exporter-0.7.10.linux-amd64.tar.gz
tar -zvxf process-exporter-0.7.10.linux-amd64.tar.gz
cd process-exporter-0.7.10.linux-amd64/
./process-exporter

可通过 process-exporter --help 查看命令帮助,默认监听:9256端口

process-exporter配置项

通过yml方式配置

# 若监控主机上所有进程
process_names:
  - name: "{{.Comm}}"
    cmdline:
    - '.+'
# 若监控主机上某个进程
process_names:
 - name: "{{.Matches}}"
   cmdline:
   - 'hadoop'

模板变量说明:

{{.Comm}}           包含原始可执行文件的基本名称,即 /proc/<pid>/stat

{{.ExeBase}}        包含可执行文件的基本名称

{{.ExeFull}}        包含可执行文件的标准路径

{{.Username}}       包含有效用户的用户名

{{.Matches}}        包含所有由于应用cmdline正则表达式而产生的匹配项

{{.PID}}            包含过程的PID。请注意,使用PID意味着该组将仅包含一个进程

{{.StartTime}}      包含过程的开始时间。与PID结合使用时,这很有用,因为PID会随着时间的推移而被重用

启动时附带配置文件:

./process-exporter  -config.path process-exporter.yml

配置prometheus动态配置文件

  - job_name: "process"
    file_sd_configs:
      - files: [/usr/local/prometheus-2.42.0.linux-amd64/sd_config/process.yml]
        refresh_interval: 5s

新增加一个process.yml到sd_config

- targets:
  - 127.0.0.1:9256

file

成功

导入到grafana

id 249,直接导入:
file

正文到此结束
本文目录