Prometheus 初体验

本文环境 Redhat Linux 6.7, Prometheus 2.2.1,node_exporter 1.5.2

介绍

Prometheus 是2012年由 SoundCloud 开源的系统监控和报警工具集,在 《Google SRE 运维解密》一书中也提到与Google内部的Borgmon思想一致。使用 Go 语言开发,适用于各个平台。

安装

[root@bj1eccap01 ~]# tar -xvzf prometheus-2.2.1.linux-amd64.tar.gz 
[root@bj1eccap01 ~]# cd prometheus-2.2.1.linux-amd64
[root@bj1eccap01 prometheus-2.2.1.linux-amd64]# ./prometheus --help
usage: prometheus [<flags>]

配置

安装包下有一个默认的配置文件,是 YAML 格式,默认配置文件包括三个分区:globalrule_filesscrape_configs

global控制 Prometheus 服务器的全局配置。scrape_interval 决定数据抓取的间隔。evaluation_interval 决定数据计算的间隔,Prometheus会根据rule_file来产生新的时间序列值。

rule_files决定规则文件的保存路径。

scrape_config决定Prometheus监控的资源。Prometheus通过HTTP暴露自己的数据,因此也可以监控自己的健康状况。

启动

启动非常简单

[root@bj1eccap01 prometheus-2.2.1.linux-amd64]# ./prometheus --config.file=prometheus.yml

这之后就可以通过浏览查看服务的运行状况了,打开浏览器输入 http://localhost:9090/graph

Prometheus 提供了两种方式查看指标 graph 模式可以直接看到指标曲线,metrics 则看到原始的监控数据。通过切换到 console 界面可以看到。

node_exporter 安装

node_exporter 用来收集服务器的监控信息,目前稳定版本为1.15.2。node_exporter 默认使用 9100 端口监听,Prometheus 会从 node_exporter 中获取信息。

[root@bj1eccap01 ~]# tar -xzvf node_exporter-0.15.2.linux-amd64.tar.gz
[root@bj1eccap01 ~]# cd node_exporter-0.15.2.linux-amd64
[root@bj1eccap01 node_exporter-0.15.2.linux-amd64]# ./node_exporter

运算与统计

Prometheus 提供了一套查询语言,支持运算以及一些常用的统计运算。

运算符号

Prometheus 支持如下运算符。

运算符

说明

+

加法

-

减法

*

相乘

/

相除

%

取摸运算

==

相等

!=

不相等

>

大于

<

小于

>=

大于或等于

<=

小于或等于

and

逻辑和

or

逻辑或

unless

除非,取补集

统计函数

方法名

介绍

sum

求和

min

求最小值

max

求最大值

avg

取平均值

stddev

计算标准差

stdvar

count

计算总数

count_values

计算相同值的数量

bottomk

最小的k个元素

topk

最大的k个元素

quantile

参考资料: 1、Prometheus

2、Prometheus First Step

3、Prometheus 入门尝试

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏木头编程 - moTzxx

PHP 生成随机码探索

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u011415782/article/de...

18020
来自专栏从流域到海域

Jupyter notebook的安装方法

本文转载自:http://blog.csdn.net/solo95/article/details/78961288,即博主本人的博客,保留所有版权,禁止转载,...

27550
来自专栏性能与架构

快速理解linux文本分析利器awk

awk是什么 如果工作中需要操作linux比较多,那么awk是非常值得学习的 awk是一个极其强大的文本分析工具,把文件逐行的读入,以指定分隔符将每行切片,切...

39880
来自专栏linux驱动个人学习

Linux之内存描述符mm_struct

Linux对于内存的管理涉及到非常多的方面,这篇文章首先从对进程虚拟地址空间的管理说起。(所依据的代码是2.6.32.60) 无论是内核线程还是用户进程,对于内...

39250
来自专栏技术小站

p=p+1与p++的区别

24210
来自专栏Script Boy (CN-SIMO)

c++错误代码1

今天敲c++,出现一个错误,这个题目错误代码如下: ? 并没有提示有错误而终止。 运行结果却错了: ? 很明显,错误的地方是变量r没有初始化。 这让我知道了,这...

24200
来自专栏Golang语言社区

Go语言的管道Channel用法实例

本文实例讲述了Go语言的管道Channel用法。分享给大家供大家参考。具体分析如下: channel 是有类型的管道,可以用 channel 操作符 <- 对其...

40050
来自专栏用户画像

逻辑覆盖 测试题

(2)  简述什么是测试用例。白盒测试的动态测试要根据程序的控制结构设计测试用例简述其原则。

11120
来自专栏深度学习之tensorflow实战篇

hive排序:distribute by 、sort by 、cluster by 、order by 区别

 3 . 总结分析 1). order by 只有一个reduce负责对所有的数据进行排序,若大数据量,则需要较长的时间。建议在小的数据集中使用order b...

29240
来自专栏

RoR: Ruby On Rails 的 Web Service 2 使用before_invocation进行验证调用权限

class BlogApi < ActionWebService::API::Base   api_method :hello_world,   :expect...

9630

扫码关注云+社区

领取腾讯云代金券