Grafana + Prometheus监控篇之Windows监控Linux服务器资源

  引言

  今天这篇文章介绍一下windows本地环境监控linux服务器资源指标,写这个的动机是源于性能测试。大家做性能测试之前一定要搞清楚一些概念性的东西,比如说什么是指标,需要监控什么指标。在很久之前,我写过一篇性能测试中关键指标的监控与分析文章,

  里面介绍了关于指标的概念。

  闲话不多说,今天介绍的工具主要是监控linux服务器上的资源指标,例如:CPU,内存,硬盘,网络等资源。

  工具介绍

  Grafana是一款用Go语言开发的跨平台开源数据度量分析及可视化工具,可以做数据监控和数据统计,带有告警功能。

  Grafana支持许多不同的时间序列数据(数据源)存储后端。每个数据源都有一个特定的查询编辑器。官方支持以下数据源:Graphite、infloxdb、opensdb、prometheus、elasticsearch、cloudwatch等。

  Prometheus(简称Prom)前身是SoundCloud的告警工具包,现已演化成一个独立的开源监控系统。属于Kurberntes所在的Cloud Native Computing Foundation。

  Prometheus把一些常用数据库、系统、中间件等的指标数据的采集做成了一个个 exporter,在生产环境中,直接导入使用就可以。采用 http 协议,使用 pull 模式,拉取数据,简单易懂。 总而言之,它是用来拉取数据的。

  Exporters:负责向prometheus server做数据汇报的程序统。而不同的数据汇报由不同的exporters实现,比如监控主机有node-exporters,mysql有MySQL server exporter等

  在Prometheus架构中,Exporters是负责收集数据并将信息汇报给Prometheus Server的组件。这篇文章我主要是监控Linux服务器资源,官方提供了node_exporter内置了对主机系统的基础监控。

  下面是Prometheus核心架构图,有兴趣的话可以了解一下: 如果看不明白,请移步官方中文文档:https://prometheus.fuckcloudnative.io/

  监控方式

  监控的流程,简单画一个草图,帮助理解 ,如图:

  

  环境搭建

  Grafana安装:https://grafana.com/grafana/download?platform=windows

  Prometheus安装: https://prometheus.io/download/

  Node_exporter安装:https://github.com/prometheus/node_exporter/releases

  总共安装上述三样程序,安装之后启动具体详情见下文:

  1、Grafana运行: 双击exe即可,默认端口3000,如图:

  

  查看进程:

  

   

   2、Prometheus运行:同上

  

  启动方式:

# 默认启动
直接双击exe文件,启动9090端口
# 自定义端口启动
prometheus.exe --config.file=prometheus.yml --web.listen-address=:8091 &

  访问Ip+8091地址,status→targets出现UP正常启动成功,如图所示:

   需要注意的地方:

  在启动这个之前,需要修改Prometheus配置, prometheus.yml配置文件请求获取exporter采集器数据,比如我的node-exporter端口号是9100

  prometheus.yml中一共定义了两个监控:一个是监控prometheus自身服务,另一个是监控Linux服务器。这里给个完整的示例:

scrape_configs:
    #prometheus自身监控
  - job_name: 'prometheus'
    static_configs:
      - targets: ['localhost:9090']

    #linux服务器监控
  - job_name: 'linux'
    static_configs:
      - targets: ['NODE_IP:9100']
        labels:
          instance: node1

  

  3、Node-exporter启动方式:

#默认启动,起来后node_exporter会监控在9100端口
./node_exporter  
#自定义启动
nohup ./node_exporter --web.listen-address=":9101" &

  日志追加:

nohup ./node_exporter > ./nohup.out 2>&1 &

  如图:

   进程查看命令:

ps -ef | grep node_
查看进程
netstat -tunlp | grep node
查看端口
netstat -tunlp | grep 9101

  如图:

  前端Grafana配置面板设置

  启动grafana后,浏览器输入:ip+3000端口,默认账号:admin,密码:admin

  既然我们已经拿到了数据,那首先就配置数据源,如图:

  主要是这个url配置对,这个8091就是prometheus服务的端口。

 

   导入监控模板,如图:

  

   

  模板地址:https://grafana.com/grafana/dashboards

  

  选择最新的模板:

 

   将id拷贝进来,如图:

  成功之后会多一个面板:

   点击进去就可以看到非常炫丽的图形界面:

  

  总结

  以上就是windows环境下对Linux服务器资源实时监控之Grafana实例,有兴趣的话,可以动动手实践一番。 后面会继续分享Linux下Grafana监控环境的搭建与使用。欢迎加入咋们测试开发交流群学习与进步~

 
原文地址:https://www.cnblogs.com/liudinglong/p/13660936.html