Prometheus介绍及二进制部署(一)

摘要:
为了强调开源和独立维护,Prometheus于2016年加入了云原生云计算基金会,成为继Kubernetes之后的第二个托管项目。目前,许多软件原生地支持普罗米修斯,提供/度量,并且可以直接使用。因为这样的工作存在的时间很短,他们可能会在普罗米修斯到来之前消失。对于此作业,指示器将定期推送到pushgateway,然后PrometheusServer将从pushgateway中拉出。该方法主要用于服务级别的度量导出器:它用于向Prometheus公开现有第三方服务的度量。警报管理器:从普罗米修斯服务器接收到警报后,它将删除重复的数据、数据包和路由到接收方法以发送警报。

一、Prometheus是什么

Prometheus是什么
Prometheus(普罗米修斯)是一个最初在SoundCloud上构建的监控系统。自2012年成为社区开源项目,拥有非常活跃的开发人员和用户社区。为强调开源及独立维护,Prometheus于2016年加入云原生云计算基金会(CNCF),成为继Kubernetes之后的第二个托管项目。

https://prometheus.io
https://github.com/prometheus

作为新一代的监控框架,Prometheus 具有以下特点:
多维数据模型:由度量名称和键值对标识的时间序列数据

  • PromSQL:一种灵活的查询语言,可以利用多维数据完成复杂的查询
  • 不依赖分布式存储,单个服务器节点可直接工作
  • 基于HTTP的pull方式采集时间序列数据
  • 推送时间序列数据通过PushGateway组件支持
  • 通过服务发现或静态配置发现目标
  • 多种图形模式及仪表盘支持

Prometheus适用于以机器为中心的监控以及高度动态面向服务架构的监控。

二、Prometheus的组成及架构

2.1 Prometheus 由多个组件组成,但是其中许多组件是可选的:

  • Prometheus Server:用于收集指标和存储时间序列数据,并提供查询接口
  • client Library:客户端库(例如Go,Python,Java等),为需要监控的服务产生相应的/metrics并暴露给Prometheus Server。目前已经有很多的软件原生就支持Prometheus,提供/metrics,可以直接使用。对于像操作系统已经不提供/metrics,可以使用exporter,或者自己开发exporter来提供/metrics服务。
  • push gateway:主要用于临时性的 jobs。由于这类 jobs 存在时间较短,可能在 Prometheus 来 pull 之前就消失了。对此Jobs定时将指标push到pushgateway,再由Prometheus Server从Pushgateway上pull。这种方式主要用于服务层面的 metrics
  • exporter:用于暴露已有的第三方服务的 metrics 给 Prometheus。
  • alertmanager:从 Prometheus server 端接收到 alerts 后,会进行去除重复数据,分组,并路由到对收的接受方式,发出报警。常见的接收方式有:电子邮件,pagerduty,OpsGenie, webhook 等。
  • Web UI:Prometheus内置一个简单的Web控制台,可以查询指标,查看配置信息或者Service Discovery等,实际工作中,查看指标或者创建仪表盘通常使用Grafana,Prometheus作为Grafana的数据源;

 Prometheus介绍及二进制部署(一)第1张

 2.2 数据模型

Prometheus将所有数据存储为时间序列;具有相同度量名称以及标签属于同一个指标。每个时间序列都由度量标准名称和一组键值对(也成为标签)唯一标识。
时间序列格式:
<metric name>{<label name>=<label value>, ...}
示例:api_http_requests_total{method="POST", handler="/messages"}

 2.3 指标类型

Counter:递增的计数器
Gauge:可以任意变化的数值
Histogram:对一段时间范围内数据进行采样,并对所有数值求和与统计数量
Summary:与Histogram类似

 2.4 任务和实例

就Prometheus而言,pull拉取采样点的端点服务称之为instance,通常对应一个过程(实例)。具有相同目的的instance,例如,为可伸缩性或可靠性而复制的流程称为作业,构成了一个job。

scrape_configs:
    - job_name: 'prometheus'
      static_configs:
      - targets: ['192.168.5.237:9090']
   - job_name: 'node'
      static_configs:
      - targets: ['192.168.5.10:9090']

三、部署Prometheus服务

2.1 最新二进制包下载地址:https://prometheus.io/download/

wget https://github.com/prometheus/prometheus/releases/download/v2.18.0-rc.1/prometheus-2.18.0-rc.1.linux-amd64.tar.gz
tar xf prometheus-2.18.0-rc.1.linux-amd64.tar.gz -C /usr/local/
ln -s /usr/local/prometheus-2.18.0-rc.1.linux-amd64 /usr/local/prometheus

2.2 使用systemd管理prometheus服务

# vim /usr/lib/systemd/system/prometheus.service
[Unit]
Description=https://prometheus.io

[Service]
Restart=on-failure
ExecStart=/usr/local/prometheus/prometheus --config.file=/usr/local/prometheus/prometheus.yml

[Install]
WantedBy=multi-user.target

 2.3 启动服务

# systemctl daemon-reload
# systemctl start prometheus.service 

2.4 访问服务9090端口

http://192.168.5.55:9090/graph

2.5 默认的metrics接口地址

http://192.168.5.55:9090/metrics

免责声明:文章转载自《Prometheus介绍及二进制部署(一)》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇使用javaMail接收邮件(比较全)软件测试从业者必备的高频Linux命令下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

nginx 之 https 证书配置

HTTPS原理和作用 为什么需要HTTPS 原因:HTTP不安全 传输数据被中间人盗用、信息泄露 数据内容劫持、篡改 HTTPS协议的实现 对传输内容进行加密以及身份验证 对称加密:加密秘钥和解密秘钥是对等的,一样的 非对称加密: HTTPS加密协议原理:   中间人伪造客户端和服务端:(中间人可以伪装成客户端和服务端,中间人可以对数据进行劫持,不...

Adblock Plus 规则

https://easylist-downloads.adblockplus.org/easylistchina.txt https://easylist.to/easylist/easylist.txt https://easylist-downloads.adblockplus.org/easyprivacy.txt https://easylist-...

prometheus监控elasticsearch

prometheus监控es,同样采用exporter的方案。 项目地址: elasticsearch_exporter:https://github.com/justwatchcom/elasticsearch_exporter 1、安装部署 现有es三节点的集群,环境大概如下: 主机 组件 192.168.75.11 prometheus...

Prometheus监控学习笔记之360基于Prometheus的在线服务监控实践

0x00 初衷 最近参与的几个项目,无一例外对监控都有极强的要求,需要对项目中各组件进行详细监控,如服务端API的请求次数、响应时间、到达率、接口错误率、分布式存储中的集群IOPS、节点在线情况、偏移量等。 比较常见的方式是写日志,将日志采集到远端进行分析和绘图,或写好本地监控脚本进行数据采集后,通过监控系统客户端push到监控系统中进行打点。基本上我们需...

docker 使用 ltp分词和pos标注

1.安装docker  sudo apt-get install docker.io 2.获取ltp的docker容器 dockerfile文件在 https://github.com/HIT-SCIR/ltp/blob/master/Dockerfile 下面。获取docker配置文件后 docker build -t ltp/ltp .   另外一种方...

Gitlab--安装及汉化

简介 gitlab是一个利用 Ruby on Rails 开发的开源应用程序,实现一个自托管的Git 项目仓库,可通过Web界面迚行访问公开的戒者私人项目。Ruby on Rails 是一个可以使你开发、部署、维护 web 应用程序变得简单的框架。GitLab 拥有与Github 类似的功能,能够浏览源代码,管理缺陷和注释。可以管理团队对仓库的访问,它非常...