总结:Grafana-程序员宅基地

技术标签: grafana  Powered by 金山文档  其它  K8S  

一、介绍

Grafana 是一个开源的数据可视化工具,它可以帮助用户将数据源中的数据进行图形化展示和实时监控,以便于用户能够更加直观地理解数据。Grafana 支持多种数据源,包括 Graphite、Elasticsearch、InfluxDB、Prometheus 等,也支持多种展示方式,如图表、仪表盘、地图、日历等。

Grafana 的主要作用包括:

  1. 数据可视化:通过 Grafana,用户可以将复杂的数据转化成易于理解的图表和仪表盘,并在一个界面中集中展示多个数据源的数据。

  1. 实时监控:Grafana 支持实时监控,可以帮助用户实时了解系统状态、性能等指标的变化情况。

  1. 告警与通知:Grafana 可以设置告警规则,当某些指标达到预设的阈值时,会自动发送通知,提醒用户关注和处理。

  1. 可扩展性:Grafana 支持插件式的开发模式,用户可以通过插件扩展功能,满足自己的特定需求。

总之,Grafana 是一款功能强大的数据可视化工具,可以帮助用户更好地理解数据,提高数据分析效率,提升工作效率。

二、数据源

Grafana 支持多种数据源,以下是其中一些主要的数据源:

  1. Graphite:Graphite 是一个开源的监控工具,Grafana 可以通过 Graphite 数据源将 Graphite 采集的监控数据进行可视化展示。

  1. Elasticsearch:Elasticsearch 是一个分布式搜索和分析引擎,Grafana 可以通过 Elasticsearch 数据源将 Elasticsearch 中的数据进行可视化展示。

  1. InfluxDB:InfluxDB 是一个高性能的时间序列数据库,Grafana 可以通过 InfluxDB 数据源将 InfluxDB 中的数据进行可视化展示。

  1. Prometheus:Prometheus 是一个开源的监控系统,Grafana 可以通过 Prometheus 数据源将 Prometheus 采集的监控数据进行可视化展示。

  1. MySQL:MySQL 是一个开源的关系型数据库,Grafana 可以通过 MySQL 数据源将 MySQL 数据库中的数据进行可视化展示。

  1. PostgreSQL:PostgreSQL 是一个开源的关系型数据库,Grafana 可以通过 PostgreSQL 数据源将 PostgreSQL 数据库中的数据进行可视化展示。

  1. Microsoft SQL Server:Microsoft SQL Server 是微软公司开发的一款关系型数据库管理系统,Grafana 可以通过 Microsoft SQL Server 数据源将 SQL Server 数据库中的数据进行可视化展示。

  1. OpenFalcon

除此之外,Grafana 还支持许多其他数据源,如 CloudWatch、OpenTSDB、MongoDB、Zabbix 等。

三、模板变量

1、案例

来源:https://blog.csdn.net/fu_huo_1993/article/details/115026228

想配置如下效果:可以支持变量查询,选择不同的变量查询的结果不一样

步骤

1、创建一个Dashboard

2、设置模板变量

在Dashboard页面点击小齿轮️图标。

点击创建一个变量

添加 nodename 变量,获取服务器的类型

添加 instance 变量。

注意:

instance变量的值是根据上一步 nodename 变量的值而来的,及选择不同的 nodename,instance 的值应该是不同的。及在 instance 变量的查询语句中需要引用 nodename 变的值,通过 $nodename 即可引用。

做完上方出现的1,2两步,即可出现需求中出现的画面。

创建一个图表,监控一下 cpu 的使用率

2、变量类型说明

变量有很多类型,比如上面的案例我们用的是最常用的Query,即从数据源查询变量,当然,我们有还有其它的类型。

Type为变量的类型,总共有六种类型:Interval(时间间隔类),Query(查询类),Datasource(数据源类型),Custom(自定义类),Constant(常量类),Ad hoc filters

下面对类型逐一介绍。

  1. Query 变量类型:

这是 Grafana 中最常用的变量类型之一,允许您从指定的数据源中检索值,并在仪表板中使用这些值。

如Prometheus配置:https://blog.csdn.net/u010039418/article/details/128009378

如Mysql配置:https://www.jianshu.com/p/fe8bab704716

  1. Custom 变量类型:

自定义变量类型允许您手动指定变量的值列表。这对于需要手动指定常量列表的情况非常有用。例如,您可能需要为特定的环境或服务指定一组常量。

如下案例,多个value用逗号隔开

效果如下:

  1. Constant 变量类型:

常量变量类型是最简单的变量类型,允许您手动指定单个值。常量变量对于需要在整个仪表板中使用静态值的情况非常有用。例如,您可能需要指定一个特定的时间范围,以便在仪表板中筛选数据。

案例:

首先定义一个模板ID常量:

然后使用此常量从策略表查询数据(只查模板ID为50的策略列表):

查询结果:

四、模板库

在 Grafana 网站上,你其实可以找到很多别人已经做好的仪表,可以用来监测非常多标准化的服务。

Grafana 的仪表盘市场:https://grafana.com/grafana/dashboards[8]

比如说针对以下一些服务的标准仪表盘就可以在这里找到

  • JVM

  • Spring Boot

  • MySQL 监控

等等很多,我们选择一个SpringBoot相关的模板吧:SpringBoot APM Dashboard | Grafana Labs

点击下载Json。然后打开我们自己的Grafana服务,选择导入刚才的Json文件并填写相关表单:

按照要求填写即可,效果如下:

五、SimpleJson

来源:https://blog.csdn.net/wonain/article/details/103291962

1、介绍

Grafana作为最火热的开源数据可视化工具,最大的特点就是支持多种数据源以及丰富的插件库了。

官方提供了Elasictsearch、Prometheus、Mysql等常见数据库的数据源。

社区也提供了支持Zabbix监控数据展示的数据源,但是实际应用中仍会遇到现有数据源无法满足需求的情况。比如Grafana没有现成插件支持从MongoDB等其他数据库中读取数据。

SimpleJson是Grafana开源社区提供的数据源,它本身并不依赖某种特定的后端存储,只需要后端能实现Grafana报表的几个查询接口就行,可以说给开发者提供了很大的想象空间了。

SimpleJson是Grafana众多数据源插件中的一种,但它又不像其他插件配置好数据库信息就能用,开发者需要自己实现一部分数据源插件的功能来使SimpleJson插件能够使用。

有一些组件就是基于SimpleJson以及Grafana插件规范定义自己的查询的,openfalcon-rrd数据源好像就是的,具体可以研究下。

2、接口规范

SimpleJson后端需要实现的四个接口:

  • / 用于数据源配置界面的"Test connection"调用,若后端服务器正常应返回 200 状态码

  • 接口随便返回个数据即可,只要返回码是200

  • /search 用于 panel 面板中查询有哪些可用的指标

  • 此接口返回select的选项。比如前端提供参数region,后端返回az列表。

  • 当然,也可以不提供参数,反正后端返回list即可。

  • 甚至,后端可以不用开发此接口,那么前端的选项就是空的。如下图所示,/search接口就没有返回任何信息

  • /query 基于用户的查询语句,返回相应的数据

  • 上面的/search主要是返回元数据,而/query根据用户前端选择的元数据进行查询,返回的格式要遵循grafana格式即可。

  • /annotations 返回注释内容

  • 也可以不实现

问题:图中只有一个参数选项,如果我希望获取多个值呢?比如ip,uuid,metric,tag等,怎么办?

解决办法:可以在选项中一起填上,后端去解析即可,如:10.15.8.20#mem.free#mem=0

然后后端获取到这个字符串之后,根据#去分隔,分别获取到不同的值即可。

3、案例

Grafana SimpleJson 是 Grafana 支持的一种数据源类型,用于通过 HTTP API 获取数据,并将其转换为 Grafana 所需的格式,从而实现数据展示。

下面是一个简单的 SimpleJson 配置案例:

  1. 创建一个简单的 HTTP API,返回一个 JSON 格式的数据。例如,下面的代码是一个返回随机数的 PHP 脚本:

<?php
header('Content-Type: application/json');
echo json_encode([
    'data' => [
        ['time' => time(), 'value' => rand(0, 100)],
        ['time' => time() - 60, 'value' => rand(0, 100)],
        ['time' => time() - 120, 'value' => rand(0, 100)],
    ]
]);
?>
  1. 在 Grafana 中创建一个 SimpleJson 数据源,将 URL 设置为上面创建的 API 地址。例如,URL 可以是 http://example.com/random.php

  1. 在 Grafana 中创建一个新的仪表盘,并添加一个图表面板。

  1. 在图表面板中,选择 SimpleJson 数据源,并在查询编辑器中输入查询语句。例如,可以使用类似下面的查询语句:

SELECT
  UNIX_TIMESTAMP(time) as time_sec,
  value
FROM
  data
WHERE
  $__timeFilter(time)
  1. 保存并刷新仪表盘,即可看到随机数的实时变化情况。

以上配置案例只是一个简单的示例,实际应用中需要根据具体的数据源和查询语句进行配置。但是,通过 SimpleJson 数据源,可以轻松地将各种数据源的数据转换为 Grafana 可以使用的格式,并进行展示和分析。

参考:

【监控仪表系统】Grafana 中文入门教程 | 构建你的第一个仪表盘_grafana读音_逆流°只是风景-bjhxcc的博客-程序员宅基地

六、插件

1、介绍

grafana的插件功能很强大,本质上对接各个数据源都是通过插件开发的,比如Druid数据源插件、OpenFalcon插件,Prometheus插件等.

grafana有很多原生支持的插件,当然,我们也可以自己写插件,甚至,我们可以按照我们需求改原生的插件,比如Druid就被晓宇改过,所以下面Hubble-Druid显示Unsigned。

2、什么时候需要修改插件呢?

当数据源选项不满足我们需要的时候,我们就可以修改插件了,比如Druid插件,我们想多增加一些日期选择:

3、DeepFlow插件

来源:https://zhuanlan.zhihu.com/p/597923244?utm_id=0

在 DeepFlow 宣布开源以后,我们基于社区版重新设计了若干插件。包括:

Data source plugin:DeepFlow Querier,用于为 Grafana 提供 DeepFlow 的数据

Panel plugin:DeepFlow AppTracing,用于展示分布式追踪火焰图

Panel plugin:DeepFlow Topo,用于展示服务之间的访问关系

这些定制化插件,配合 Grafana 原本提供的一系列标准图表,可以构建出一组完整的 DeepFlow 可观测性视图。

七、Grafana还支持哪些图表?

1、Grafana支持的常见图表

从DeepFlow插件我们知道,Grafana支持自定义插件,可以根据特定需求定制和扩展图表类型。比如拓扑图、火焰图等。

以下是一些Grafana支持的常见图表类型:

  • 折线图:用于显示随时间变化的数据,通常用于监视系统性能、应用程序指标、传感器数据等。

  • 柱状图:用于显示各种类别之间的比较,通常用于分析销售数据、用户行为、流量数据等。

  • 饼图:用于显示各个部分在整体中的比例,通常用于展示数据占比、分布情况等。

  • 仪表盘:用于显示一个或多个指标的当前值和历史趋势,通常用于监视系统性能、关键指标等。

  • 热力图:用于显示数据的密度和分布情况,通常用于分析流量热图、用户行为、地理信息等。

  • 散点图:用于显示数据之间的关系和趋势,通常用于分析实验数据、传感器数据等。

  • 桑基图:用于显示数据的流程和关系,通常用于分析流量、用户行为等。

除了上述常见的图表类型之外,Grafana还支持更多的图表类型和可视化方式,例如雷达图、树形图、Sunburst图等。此外,Grafana还支持自定义插件,可以根据您的特定需求定制和扩展图表类型。

2、grafana支持火焰图吗?

是的,Grafana支持火焰图。Grafana是一个强大的开源数据可视化工具,可以通过插件来扩展其功能。其中一个流行的插件是FlameGraph插件,可以在Grafana中创建和展示火焰图。

使用FlameGraph插件,您可以将火焰图添加到Grafana的仪表板中,以便在监视和分析应用程序性能时更好地理解代码执行路径和函数调用关系。该插件可以与多种数据源集成,例如Prometheus、InfluxDB、Elasticsearch等,使您能够在不同的数据源中轻松地创建和显示火焰图。

要在Grafana中使用火焰图,您需要安装并配置FlameGraph插件,并将其与您的数据源进行连接。接下来,您可以在仪表板上创建一个新的面板,并将火焰图添加到该面板上。然后,您可以选择要监视的应用程序,并设置相应的参数,例如时间范围、聚合方式等。

需要注意的是,火焰图通常用于分析CPU性能问题,因此您需要收集足够的CPU利用率数据,以便生成准确的火焰图。另外,生成火焰图可能需要一定的计算资源,因此在处理大量数据时,可能需要考虑优化和扩展您的计算环境。

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

智能推荐

服务器发送信息给arduino,arduino通过esp8266模块发送数据到云服务器-程序员宅基地

文章浏览阅读1.4k次,点赞2次,收藏25次。arduino通过esp8266模块发送数据到云服务器我是代码小白,一个正在做毕设的秃头少年。鄙人拙作,有不当之处,还请指教。最近买了一套arduino设备,打算做一个物联网设备小玩意,可是怎么把数据上传到云服务器可愁坏我了。通过对比实验,我决定用esp8266wifi模块进行通信。云服务器的话,我现在还没写相应的代码,所以先用Onenet平台进行配置。Onenet平台进行配置1.进入Onenet..._esp8266 arduino wifi发送数据

latex h t b p是什么意思_latex htpb-程序员宅基地

文章浏览阅读1.4w次,点赞9次,收藏17次。常用选项[htbp]是浮动格式:『h』当前位置。将图形放置在正文文本中给出该图形环境的地方。如果本页所剩的页面不够,这一参数将不起作用。『t』顶部。将图形放置在页面的顶部。『b』底部。将图形放置在页面的底部。『p』浮动页。将图形放置在一只允许有浮动对象的页面上。在table或者figure 后加 [!htb] 是系统忽略“美学”标准,把表格和图片插入到你的代码中,是动的,但是不加感叹号,它就是按顺序选择h(此处),t(上方),b(下方),所以为了让图片随着你的代码移动,最好加一个[!htb]_latex htpb

【转载】linux下的usb抓包方法-程序员宅基地

文章浏览阅读67次。1 linux下的usb抓包方法1、配置内核使能usb monitor:make menuconfigDevice Drivers --> USB Support --> USB Monitor --> Sel..._linux安装tcpdump 查看usb

计算机组成pc em ir,计算机组成 课程设计报告.doc-程序员宅基地

文章浏览阅读164次。计算机组成 课程设计报告计算机组成原理课程设计报告姓 名:班 级:学 号:指导老师:2016年 6月31日目 录第一章 背景知识与课设任务概述11.1课设目的11.2课设任务11.2111.2211.2321.2421.252第二章 课设内容32.1指令的执行流程32.1.132.1.242.1.352.2存储器62.2.162.3运算器72.3.172.4硬件系统组成122.4..._计算机组成课程设计报告

python青果教务系统抢课_名额不够,技术来凑,利用Python实现教务系统强制性抢课...-程序员宅基地

文章浏览阅读1.3k次。最近一学期一次的抢课大戏又来了,几家欢乐几家愁。O(∩_∩)O哈哈~(l我每次一选就过了hah,我还是有欧的时候滴)。看着他们盯着教务系统就着急,何况我们那教务系统,不想说什么。emmm 想周围的朋友,正好下午利用扩容前一段时间写了个小脚本帮助朋友抢课。(当然抢到了啦,^_^)私信小编001即可获取大量Python学习资料,名额有限因为时间不够,来不及仔细琢磨,我第一想法就是直接提交选课的数据包(..._青果教务系统抢课

windows 加 switchyomega + burp 抓https包-程序员宅基地

文章浏览阅读4.6k次。很简单,下载证书后导入到受信任根目录证书下载,直接在代理状态浏览器访问burp点击CA就可以下载了 设置该证书全部信任,,switchyomega 设置如下即可 就可以抓https的包了 ...

随便推点

解决atom上gcc无法识别 <ros/ros.h>_ros类型无法识别-程序员宅基地

文章浏览阅读335次。找到插件 linter-gcc在Settings里找到GCC Inlude Path和GCC -isystemInclude Paths两栏填入ros的Include路径 /opt/ros/noetic/include注意ros版本不同路径可能有所不同,可以在先文件夹里找一找确定一下_ros类型无法识别

java 解析 modbus rtu_ModBus-RTU详解-程序员宅基地

文章浏览阅读5.7k次,点赞2次,收藏13次。Modbus 一个工业上常用的通讯协议、一种通讯约定。Modbus协议包括RTU、ASCII、TCP。其中MODBUS-RTU最常用,比较简单,在单片机上很容易实现。虽然RTU比较简单,但是看协议资料、手册说得太专业了,起初很多内容都很难理解。所谓的协议是什么?就是互相之间的约定嘛,如果不让别人知道那就是暗号。现在就来定义一个新的最简单协议。例如,协议: “A” --“LED灭”“B” --“报警..._java modbus4j-rtu 二进制数字意义

2021-07-18-程序员宅基地

文章浏览阅读43次。从零开始实现简易版本SpringIoC&DI&MVCSpring源码进修中,实现一个简易版本的Spring,包含以下主要内容:IoC,DI,MVC,已完成基本的功能。代码量还算一般,特此记录以共勉。首先是整个项目的基本思路。项目实现的功能就是从前端发一个请求,后端根据请求解析到后端的相应方法进行处理,完成后将结果进行返回。代码需要完成请求路径和类+方法的对应。配置阶段配置web.xml:DispatcherServlet设定init-param:contextConfigL

507页XX市应急管理局智慧矿山煤矿数字化矿山技术解决方案_18万字应急管理局智慧矿山煤矿数字化矿山技术解决方案word-程序员宅基地

文章浏览阅读542次。只有在单系统自动化的基础上,通过高速网络接入各单系统,充分数据融合,建立合理的联动机制才能完成从单系统自动化到综合自动化的转变,该部分的转变从投入的资金和实现的容易度相对来讲可实现性和可控性都比较容易,但是从综合自动化向数字化矿山发展,涉及的面比较广,必须由多方共同来推进,一般涉及到“综合自动化”、“空间数字化”及“管理信息化”三大方面,三者缺一不可,通过三者的有机融合,再通过合适的平台例如三维可视化平台进行展示,同时通过科学合理的管理制度和流程加以应用才是真正意义上有血有肉的数字化矿山。_18万字应急管理局智慧矿山煤矿数字化矿山技术解决方案word

Tomcat官网地址-程序员宅基地

文章浏览阅读1.4w次,点赞8次,收藏7次。Tomcat官网地址_tomcat官网

汇编指令长度计算_汇编指令占多少字节-程序员宅基地

文章浏览阅读5.1k次,点赞11次,收藏58次。指令长度与寻址方式有关系,规律或原则如下:一、没有操作数的指令,指令长度为1字节。如es:ds:cbwxlat等。二、操作数只涉及寄存器的指令,指令长度为2字节。如mov al,[si]mov ax,[bx+si]mov ds,ax等。三、操作数涉及内存地址的指令,指令长度为3字节。如mov al,[bx+1]mov ax,[bx+si+3]lea di,[1234]mov [2345],ax等。四、操作数涉及立即数的指令,指令长度为:寄存器类型+2。8位寄存器,寄存器_汇编指令占多少字节