Prometheus 是什么?
Prometheus是一套开源的监控&报警&时间序列数据库的组合,起始是由SoundCloud公司开发的。随着发展,越来越多公司和组织接受采用Prometheus,社区也十分活跃,他们便将它独立成开源项目,并且有公司来运作。google SRE的书内也曾提到跟他们BorgMon监控系统相似的实现是Prometheus。现在最常见的Kubernetes容器管理系统中,通常会搭配Prometheus进行监控。
Prometheus 的优点
1. 配置灵活
使用过zabbix的同学应该都体验过安装时候的安装依赖包的痛苦,而premetheus核心部分只有一个单独的二进制文件,下载解压安装即可,没有依赖的第三方库。
2. 监控更多多样性
prometheus支持多种语言的的客户端,我们通过客户端方便对核心业务进行埋点,比如下单,添加购物车等流程。
而且prometheus已经有非常多的系统集成:比如
应用层面的监控:nginx,haproxy,mysql ,docker等
系统层面如:SNMP协议监控,主机监控,进程监控
容器云监控:docker,k8s openstack私有云
3. 非常高效的存储
平均一个采样数据占 ~3.5 bytes左右,320万的时间序列,每30秒采样,保持60天,消耗磁盘大概228G。
prometheus的架构
对照图中的每一部分进行介绍:
prometheus的工作流程
prometheus server 定期从配置好的jobs或者exporters中拉metrics.或者接受来自pushgateway发过来的metrics,或者从其他的prometheus server中拉取metrics
prometheus server 在本地存储收集到的metrics,并运行已经定义好的arlt.rules,记录新的时间序列或者向alertmanager推送报警
Alertmanager根据配置文件,对接受的警报进行处理,发出告警
在图形界面中,可视化采集数据,可以使用别人写好的grafana模板。
prometheus 部署
下载地址:https://github.com/prometheus/prometheus/releases/
[root@zmedu-17 ~]# tar xf prometheus-2.7.2.linux-amd64.tar.gz [root@zmedu-17 ~]# mv prometheus-2.7.2.linux-amd64 /usr/local/prometheus[root@zmedu-17 ~]# cd /usr/local/prometheus/[root@zmedu-17 prometheus]# pwd[root@zmedu-17 prometheus]# lsconsole_libraries NOTICE promtoolconsoles prometheusLICENSE prometheus.yml
[root@zmedu-17 prometheus]# ./prometheus --versionprometheus, version 2.7.2 (branch: HEAD, revision: 82f98c825a1437c0a24056eb4dc986d9a3fc7fae) build user: root@ab86c672c33a build date: 20190302-14:57:04 go version: go1.11.5[root@zmedu-17 prometheus]# [root@zmedu-17 prometheus]# ./prometheus & #后台启动[1] 66474
通过网址访问