前言

随着公司postgresql数据库被广泛应用,尤其是最近多个项目在做性能测试的时候都是基于postgresql的数据库,为了确定性能瓶颈是否会出现在数据库中,数据库监控也被我推上了日程。在网上找了一遍好像没有特别好的监控工具,虽然推荐比较多的是pgwatch,但是部署比较麻烦,需要Linux环境,然而公司大部分都是Windows而且后期推广也不是很方便,因此果断放弃了。

最近在做一个服务器性能监控时发现telegraf+influxdb+grafana的组合比较不错,然后去官网和github上查了一下发现telegraf可以对postgresql进行监控,瞬间惊喜万分。下面简单介绍一下监控postgresql的配置方法:

环境

首先去官网下载telegraf、influxdb和grafana:

telegraf: 是一个用 Go 编写的代理程序,可收集系统和服务的统计数据,并写入到 InfluxDB 数据库。下载地址

influxdb:是一个用 Go 编写的目前比较流行的时间序列数据库。下载地址

grafana:是一个开箱即用的可视化工具,具有功能齐全的度量仪表盘和图形编辑器,有灵活丰富的图形化选项,可以混合多种风格,支持多个数据源特点。下载地址

三者之间的关系为:telegraf(监控数据收集)->influxdb(监控数据存储)->(监控数据展示)

部署

本次描述的方法是在Windows环境下部署实施,如果需要在Linux下部署请参考grafana + influxdb + telegraf , 构建性能监控平台

1、influxdb部署方式

下载influxdb包后解压,修改influxdb.conf配置文档中的以下内容:

修改[data]下内容dir和wal-dir路径为本地存储路径,如下图所示:

之后设置[admin]下的配置参数如下即可:

保存配置文件后,在当前文件夹路径下启动cmd(在文件夹路径内输入cmd回车即可),在cmd窗口中输入:influxd -config influxdb.conf回车,启动influxdb数据库。

在浏览器中输入http://127.0.0.1:8083/查看是否显示influxdb数据库界面,如下图所示:

出现该界面后influxdb部署完成。

2、telegraf部署方式

下载telegra包后解压,修改telegraf.conf配置文档中的以下内容:

##output##中urls=["influxdb服务地址:监听端口"],database=“存储监控数据的数据库名称”,如下图所示:

之后在配置最下方加入如下内容进行postgresql监控配置:

[[inputs.postgresql]]
  address = "postgres://postgres:postgres@localhost"          #"postgres://数据库用户:密码@数据库ip/指定的数据库(可选)"
  ignored_databases = ["template0", "template1"]                 #忽略[]内的数据库监控,不能与database同时使用
  #databases = ["test"]                                                           #只监控[]内数据库,不能与ignored_database同时使用

配置完成后保存conf文件,并在当前文件夹路径下启动cmd(在文件夹路径内输入cmd回车即可),在cmd窗口中输入:telegraf -config telegraf.conf启动监听

可在influxdb中查看是否生成telegraf数据库及postgresql表单信息,如下图所示:

相关postgresql监控内容参数意义可参考官方文档

3、grafana部署方式

下载grafana部署包后解压,双击\bin\grafana-server.exe,然后在浏览器中输入:http://127.0.0.1:3000/,如下图所示:

输入用户名和密码,默认均为:admin,登录成功后配置数据源,如下图所示:

一般初始过程中会提示配置数据源,可能与本过程存在差异,但是不影响配置

此处在Data Sources中点击“Add data source”添加influxdb数据源,选择数据类型为influxdb,之后配置相关参数,如下图所示:

配置完成后点击“Save&Test”按钮,提示如下信息:

连接成功并保存。切换到“Dashboards”->“New”界面

在新界面中添加Graph等展示图,如下图所示:

点击新生成的graph界面的标题处,选择“Edit”进行参数编辑,如下图所示:

修改General中的Title为相关监控参数名

修改Metrics中的Panel Data Source为之前配置的telegraf,并选取展示数据,如下图所示:

配置完成后可以看到展示结果,如下图所示:

如果未显示数据,可以设置右上角的展示时间范围,如下图所示:

到此为止一个最基本的postgresql读取磁盘块(blks_read)的监控配置完成,下面是一个简单的系统及postgresql监控界面如下图所示:

优化

为了让监控框架的启动方式更加简洁,我这里进行了一下bat一键启动,代码如下:

基于telegraf+influxdb+grafana进行postgresql数据库监控的更多相关文章

  1. [转帖] 基于telegraf, influxdb, grafana 建立 esxi 监控

    [系统集成] 基于telegraf, influxdb, grafana 建立 esxi 监控 https://www.cnblogs.com/hahp/p/7677420.html 之前在 nagi ...

  2. Telegraf+InfluxDB+Grafana快速搭建实时监控系统 监控postgresql

    Telegraf+InfluxDB+Grafana快速搭建实时监控系统  监控postgresql

  3. [系统集成] 基于telegraf, influxdb, grafana 建立 esxi 监控

    之前在 nagios 上建立了 esxi 监控,指标少.配置麻烦.视觉效果差.最近我把 esxi 监控迁移到了 influxdb+grafana 平台上,无论是监控指标.可操作性还是视觉效果都有了很大 ...

  4. Telegraf+Influxdb+Grafana自动化运维监控

    概述:Telegraf收集信息,influxdb时序数据库存储数据,grafana平台展示数据,并进行监控告警,组成一个自动化运维监控平台. 一.influxdb ​ InfluxDB是一个由Infl ...

  5. 基于jmxtrans+influxdb+grafana实现对canal监控

    最近在调研canal数据同步系统的监控方案,网上关于jmxtrans+influxdb+grafana监控kafka的文档很多,没有监控canal的.通过几天的摸索,大致明白了来龙去脉.监控流程基本是 ...

  6. 使用Telegraf + Influxdb + Grafana 监控SQLserver服务器的运行状况

    使用Telegraf + Influxdb + Grafana 监控SQLserver服务器的运行状况 前言 本文在Debian9下采用Docker的方式安装Telegraf + Influxdb + ...

  7. Telegraf+InfluxDB+Grafana搭建服务器监控平台

    Telegraf+InfluxDB+Grafana搭建服务器监控平台 tags:网站 个人网站:https://wanghualong.cn/ 效果展示 本站服务器状态监控:https://statu ...

  8. 使用 Metrics.net + influxdb + grafana 搭建项目自动化监控和预警方案

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明.本文链接:https://blog.csdn.net/qq_25042791/article/d ...

  9. 搭建jmeter+influxdb+grafana压测实时监控平台(超详细,小白适用)

    1.前言 在使用jmeter做性能测试的时候,监控系统性能的时候,无论是使用插件还是报告生成,都没法实现实时监控.使用JMeter+Influxdb+Grafana可以实现实时监控. 本次环境搭建各软 ...

随机推荐

  1. Dom模型

    1.dom之对象分类 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...

  2. SxsTrace程序追踪 && 错误信息分析

    先贴错误:应用程序无法运行,并行配置不正确 ,使用命令行sxstrace.exe.百度解决版本. 起因:同事给我一 EXE,然后基于 其进行开发 dll和模块,但是无法加入进程,无法运行. SxsTr ...

  3. JAVA技术图谱

  4. Linux磁盘分区(一):添加

    ***********************************************声明************************************************ 原创 ...

  5. 【JSOI2008】最大数

    https://www.luogu.org/problem/show?pid=1198 之前刚学完Splay想找题练手的时候做的,写完Splay交上去了才发现这应该是线段树裸题23333 Splay解 ...

  6. 鼠标悬停,图片放大 CSS实现

    因为最近做的项目刚好用到了这个实现,分享出来   class=enlarge 为div标签的class div img 为标签 .enlarge div img:hover{ transform: s ...

  7. replace深入

    var b = 0; var arr = []; str = str.replace(/J/g,function(){ var args = arguments; b++; arr.push(args ...

  8. Javaproject集成log4j 2.x

    log4j2和log4j在配置文件和引入jar包上出现了不同.这里做个备忘,这里使用的版本号为apache-log4j-2.3-bin.zip. 1.apache-log4j-2.3-bin.zip下 ...

  9. Python笔记·第四章—— 细数Python中的数据类型以及他们的方法

    一.数据类型的种类及主要功能 1.数字类型 数字类型主要是用来计算,它分为整数类型int和浮点类型float 2.布尔类型 布尔类型主要是用于判断,它分为真True和False两种 3.字符串类型 字 ...

  10. Hello Docker

    Docker: Build, Ship, and Run Any App, Anywhere 在任何地方构建.交付和运行任何应用 1. 引言 最近简单的学习了下Docker,本文先简要梳理下Docke ...