Prometheus运⾏框架介绍
框架结构的展⽰图 
• 我们先来看下这个部分 
这⾥是 prometheus的服务端也就是核⼼
prometheus本⾝是⼀个以进程⽅式启动,之后以多进程和多线程实现监控数据收集 计算 查
询 更新 存储 的这样⼀个C/S模型运⾏模式
本⾝的启动很简单 
如果不带参数的不考虑后台运⾏的问题
那么 prometheus 默认启动更简单
解压缩之后
./prometheus 即可之后默认监听在9090端⼜⽤来访问
• 接下来我们来看看prometheus的存储形式 
这是⼀段来⾃官⽅的 prometheus存储数据的介绍
• prometheus 采⽤的是 time-series (时间序列)的⽅式以⼀种⾃定义的格式存储在本地硬盘上
• prometheus的本地T-S(time-series)数据库以每两⼩时为间隔来分block(块)存储,
每⼀个块中又分为多个chunk⽂件,chunk⽂件是⽤来存放采集过来的数据的T-S数据, metadata 和 索引⽂件(index)
• index⽂件是对metrics(prometheus中 ⼀次K/V采集数据叫做⼀个metric) 和 labels(标签) 进⾏索引 之后存储在 chunk中
chunk 是作为存储的基本单位, index and metadata是作为⼦集
• prometheus平时是将采集过来的数据 先都存放在内存之中(prometheus对内存的消耗还是不⼩的)以类似缓存的⽅式 ⽤于加快搜索和访问
• 当出现宕机时, prometheus有⼀种保护机制叫做WAL 可以讲数据定期存⼊硬盘中以chunk来表⽰,并在重新启动时 ⽤以恢复进⼊内存
然后我们来看下⼤图中的这个部分 
这⾥⾯讲的是 prometheus 可以集成的服务发现功能
例如 Consul
prometheus本⾝跟其他的开源软件类似,也是通过定义配置⽂件来给prometheus本⾝规定需要被监控的项⽬和被监控节点
我们看下配置⽂件的模版 
配置⽂件中 规定了⼀个 ⼤的Job的名字
之后 在这个Jobs的名字下⾯ 具体来定义 要被监控的节点 以及节点上具体的端⼜信息等等
那么如果prometheus 配合了 例如consul这种服务发现软件
prometheus的配置⽂件 就不再需要⼈⼯去 ⼿⼯定义出来,⽽是能⾃动发现集群中 有哪些新
机器 以及新机器上出现了哪些新服务 可以被监控
接下来我们来看看 采集客户端的部分 
prometheus 的客户端主要有两种⽅式采集
pull 主动拉取的形式
push 被动推送的形式
pull: 指的是客户端(被监控机器)先安装各类已有exporters(由社区组织 或企业 开发的监控客户端插件)在系统上
之后, exporters 以守护进程的模式运⾏并开始采集数据
exporter本⾝也是⼀个http_server可以对http请求作出响应返回数据(K/V metrics)
prometheus ⽤ pull 这种主动拉的⽅式(HTTP get) 去访问每个节点上exporter 并采样回需要的数据
push : 
指的是 在客户端(或者服务端)安装这个 官⽅提供的pushgateway插件
然后,使⽤我们运维⾃⾏开发的各种脚本 把监控数据组织成k/v的形式 metrics形式 发送给pushgateway
之后 pushgateway会再推送给prometheus
这种是⼀种被动的数据采集模式
最后咱们来看下这个报警的部分

prometheus 本⾝并不具备报警的功能
只能通过第三⽅ 开源或者商业软件实现报警

另外
这⾥指的是 prometheus 可以依赖很多⽅式⼆次绘制监控图形⾸推Grafana
Prometheus运⾏框架介绍的更多相关文章
- [连载]《C#通讯(串口和网络)框架的设计与实现》-1.通讯框架介绍
[连载]<C#通讯(串口和网络)框架的设计与实现>- 0.前言 目 录 第一章 通讯框架介绍... 2 1.1 通讯的本质... 2 1 ...
- Java常用日志框架介绍
Java常用日志框架介绍 java日志概述 对于一个应用程序来说日志记录是必不可少的一部分.线上问题追踪,基于日志的业务逻辑统计分析等都离不日志.java领域存在多种日志框架,目前常用的日志框架包括L ...
- IOS-常用第三方开源框架介绍
iOS开发-常用第三方开源框架介绍(你了解的ios只是冰山一角) 时间:2015-05-06 16:43:34 阅读:533 评论:0 收藏:0 [点我收藏+] ...
- Java常用日志框架介绍(转)
Java常用日志框架介绍 java日志概述 对于一个应用程序来说日志记录是必不可少的一部分.线上问题追踪,基于日志的业务逻辑统计分析等都离不日志.java领域存在多种日志框架,目前常用的日志框架包括L ...
- iOS开发-常用第三方开源框架介绍
iOS开发-常用第三方开源框架介绍 图像: 1.图片浏览控件MWPhotoBrowser 实现了一个照片浏览器类似 iOS 自带的相册应用,可显示来自手机的图片或者是网络图片,可自动从网 ...
- Ligg.EasyWinApp-000: 一款Windows应用编程框架介绍
本框架(解决方案)是一个Windows应用编程框架和UI库,通过该框架,不需任何代码,通过XML配置文件,搭建任意复杂的Windows应用界面,以类似Execel公式的方式实现基本的过程控制( ...
- Prometheus 运维监控
Prometheus 运维监控 1.Prometheus 介绍详解 2.Prometheus 安装部署 3.Prometheus 配置文件详解 4.Prometheus PromSQL 常用资源 5. ...
- 面试简历书写、Flask框架介绍与快速使用、Flask演示登录页面、用户信息页面案例
今日内容概要 面试简历编写 Flask框架介绍与安装 内容详细 1.面试简历编写 # 千万不要几个小时把简历凑出来 几天到一周 # 有没有面试机会,取决于简历写得怎么样 简历写好是第一步 # 投简历的 ...
- YARN基本框架介绍
YARN基本框架介绍 转载请注明出处:http://www.cnblogs.com/BYRans/ 在之前的博客<YARN与MRv1的对比>中介绍了YARN对Hadoop 1.0的完善.本 ...
随机推荐
- javascript访问html元素的内容(2)
对于(1)中最后一个包装方式创建的是一个方法,我们必须以方法调用的方式来使用它,这和其他默认的以属性返回结果略有不同,如果有强迫症的童鞋有些伤不起,那么我们下面就把它实现为属性返回的方式: //chi ...
- Srping mvc mabatis 报错 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found):
我的Mapper采用接口+注解的方式注入 @Repository(value="customerServOutCallMapper")public interface Custom ...
- pslq常用操作
1,登录后默认自动选中My Objects 默认情况下,PLSQL Developer登录后,Brower里会选择All objects,如果你登录的用户是dba,要展开tables目录,正常情况都 ...
- 6.4 Schema 设计对系统的性能影响
前面两节中,我们已经分析了在一个数据库应用系统的软环境中应用系统的架构实现和系统中与数据库交互的SQL 语句对系统性能的影响.在这一节我们再分析一下系统的数据模型设计实现对系统的性能影响,更通俗一点就 ...
- sql server对并发的处理-乐观锁和悲观锁
https://www.cnblogs.com/dengshaojun/p/3955826.html sql server对并发的处理-乐观锁和悲观锁 假如两个线程同时修改数据库同一条记录,就会导致后 ...
- C++笔记019:C++中的const修饰的是一个真正的常量
原创笔记,转载请注明出处! 点击[关注],关注也是一种美德~ 程序一: 我们知道数组的下标不能为变量,必须是一个确定的值.在C语言中看程序: #define a 10 int main() { //第 ...
- Hadoop生态圈初识
一.简介 Hadoop是一个由Apache基金会所开发的分布式系统基础架构.Hadoop的框架最核心的设计就是:HDFS和MapReduce.HDFS为海量的数据提供了存储,则MapReduce为海量 ...
- Proxy SwitchyOmega配合Shawdowsocks使用的配置
国内环境如果想使用Shawdowsocks来FQ,几乎一定会装ProxyOmega来进行配合使用,简单讲讲ProxyOmega如何和Shawdowsocks进行协同. 准备 Google chrome ...
- Java中浮点数的精度问题 【转】
当您在计算Money的时候,请看好了!!!要不损失了别后悔!!! 现象1: public static void main(String[] args) { System.out.println(0. ...
- Linux的一些问题
2. VMware11安装deepin15 实现文件共享和屏幕分辨率放大 要点:安装 open-vm-tools open-vm-tools-desktop open-vm-tools-dkms 这 ...