zoukankan      html  css  js  c++  java
  • prometheus学习笔记(1)-mac单机版环境搭建

    注:以下所有环境均为mac笔记本

    一、安装prometheus

    brew install prometheus
    

    安装完后,默认的安装路径为:

    /usr/local/Cellar/prometheus/2.16.0/
    

    同时还会生成一个默认配置文件:/usr/local/etc/prometheus.yml

    global:
      scrape_interval: 15s
    
    scrape_configs:
      - job_name: "prometheus"
        static_configs:
        - targets: ["localhost:9090"]
    

     进入安装路径后,输入以下命令:

    ./prometheus --config.file=/usr/local/etc/prometheus.yml
    

    顺利的话,应该能正常启动,然后浏览器输入 http://localhost:9090

    菜单切换到status,还能看到一些关键参数,比如数据默认保存天数:(默认15天)

    二、安装grafana

    要展示各种漂亮的图表,就得借助grafana,仍用brew安装

    brew install grafana
    

    默认安装路径:

    /usr/local/Cellar/grafana/6.7.0
    

    启动:

    grafana-server --config=/usr/local/etc/grafana/grafana.ini --homepath /usr/local/share/grafana --packaging=brew cfg:default.paths.logs=/usr/local/var/log/grafana cfg:default.paths.data=/usr/local/var/lib/grafana cfg:default.paths.plugins=/usr/local/var/lib/grafana/plugins
    

    启动完成后,浏览http://localhost:3000/进入首页(注:如需修改默认端口,可修改/usr/local/etc/grafana/grafana.ini 这个文件),默认用户名/密码,都是admin,使用前必须更改密码

    grafana只是一个图表展示工具,必须添加数据源,才能读取到数据,参考下图:

    选择prometheus数据源,指定URL地址,然后保存即可

    三、安装pushgateway

    从官网https://prometheus.io/download/ 下载pushgateway-1.2.0.darwin-amd64.tar.gz

    解压到本地运行

    ./pushgateway
    

    启动正常的话,浏览http://localhost:9091 可以看到

     为什么要安装这个玩意儿,看下面的示意图(从网上淘的):

    客户端(不管是写代码,还是直接终端敲命令行)把数据push到网关(pushgateway),然后prometheus从网关pull数据。

    安装好之后,还要修改/usr/local/etc/prometheus.yml 不然prometheus感知不到网关的存在

    global:
      scrape_interval: 15s
    
    scrape_configs:
      - job_name: "prometheus"
        static_configs:
        - targets: ["localhost:9090"]
      # 加入下面这几行  
      - job_name: "push-metrics"
        static_configs:
        - targets: ["localhost:9091"]
        honor_labels: true
    

    加入最后这几行即可,改完后最好把prometheus重启一下,以便让配置文件生效。 

    接下来测试数据写入:先准备1个文件data.txt

    blog_visit_total{blogid="12345",domain="yjmyzz.cnblogs.com",clientip="10.0.1.1"} 20
    blog_visit_total{blogid="34567",domain="yjmyzz.cnblogs.com",clientip="10.0.1.2"} 30
    blog_visit_total{blogid="56789",domain="yjmyzz.cnblogs.com",clientip="10.0.1.3"} 40
    

    解释一下,blog_visit_total相当于指标名称,{ }里面的东西,相当于tag,可以根据tag在查询时过滤,最后的20、30、40相当于具体的指标值。

    命令行下,输入:

    curl -XPOST --data-binary @/Users/jimmy/Downloads/data.txt http://localhost:9091/metrics/job/cnblogs
    

    就把这3行数据push到网关了,注意下格式:http://localhost:9091/metrics/job/cnblogs 红色的部分,这是job名称,大家可以根据需要自己修改。

    此时再到http://localhost:9091查看一下,应该能看到刚push的数据:

    感兴趣的同学,还可以看下http://localhost:9090 ,这时候prometheus里也能感知刚添加的数据 

    prometheus底层存储是一个时序数据库,上面的curl命令,可以多跑几次,相当于持续在向时序数据库时添加记录,后面会用到。

    四、配置grafana

    到目前为止,grafana好象一直在打酱油,没派上用场,该它发挥点作用了。

    4.1 新建dashboard

    参考上图,新建1个dashboard,然后随便起个名字(上图中我已经创建了一个名为“菩提树下的杨过”的dashboard),命名的地方,在settings里(如下)

    4.2 添加图表 

    接下来,添加一个查询(Add Query)

    参考下图,将刚才的指标blog_visit_total添加进来(还可以用sum/max/min/avg这类聚合函数处理)

     图表名称可以参考下图设置:

    最后保存,这样一个基本的prometheus监控系统(单机环境)就搭建完成了。

    参考文章:

    https://prometheus.io/docs/practices/pushing/

    https://prometheus.io/download/

    https://prometheus.io/docs/introduction/overview/

    https://www.liuyixiang.com/post/96100.html

    https://blog.csdn.net/Holly_walker/article/details/103820509

  • 相关阅读:
    Windows下MySQL数据库备份脚本(二)
    pt-query-digest用法
    pt-online-schema-change 实例
    pt-kill使用
    pt-find 使用实例
    利用pt-deadlock-logger监控死锁
    pt-fifo-split使用
    bash{} 方法总结
    python psutil 模块
    Zabbix的安装与部署---问题处理(php65.6.28 mysqli 报错误 处理)
  • 原文地址:https://www.cnblogs.com/yjmyzz/p/how-to-install-prometheus-and-grafana.html
Copyright © 2011-2022 走看看