总结:Grafana

27 篇文章 6 订阅

一、介绍

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的博客-CSDN博客

六、插件

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利用率数据,以便生成准确的火焰图。另外,生成火焰图可能需要一定的计算资源,因此在处理大量数据时,可能需要考虑优化和扩展您的计算环境。

  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Grafana是一款开源的数据可视化工具,可以帮助用户通过创建仪表盘和图表来监控和分析数据。Grafana的官方文档提供了详细的说明和指南,但最初官方文档主要是以英文撰写,而中文手册则是社区自发翻译的版本。 Grafana中文手册致力于为中国用户提供更友好和易于理解的使用指南。中文手册包含了关于Grafana的各个方面的介绍,如安装、配置、创建仪表盘、数据源配置等。通过阅读中文手册,用户可以更快地上手Grafana,并了解如何使用其强大的功能来展示数据,并通过自定义查询和过滤来获取准确的分析结果。 中文手册还提供了详细的使用示例和步骤说明,用于帮助用户快速掌握各种功能和技巧。用户可以按照中文手册中的步骤逐步操作,从而更好地理解和应用Grafana。 此外,中文手册还解答了一些常见问题和疑虑,帮助用户解决可能遇到的困难和挑战。用户可以通过查询中文手册来获取关于Grafana的详细信息,并从其他用户的经验中获益。 总结来说,Grafana中文手册是一个非常有价值的资源,为中国用户提供了更便利的学习和使用Grafana的机会。无论是初学者还是有经验的用户,都可以从中文手册中获得相关的帮助和指导,提升对Grafana的理解和运用水平。 ### 回答2: Grafana中文手册是一个用于学习和使用Grafana的资源指南,它提供了关于Grafana功能和用法的详细说明。Grafana是一个开源的数据可视化和监控工具,它能够从多个数据源获取数据,并将其以可视化的方式呈现出来。 Grafana中文手册涵盖了Grafana的基本概念和术语,以及如何安装和配置Grafana。它说明了如何使用Grafana连接到各种不同的数据源,包括数据库、云服务和API。 这个手册详细介绍了Grafana的仪表盘功能,它可以创建灵活的仪表盘,将多个数据源的数据整合在一起进行可视化展示。手册中还包括了如何使用Grafana的查询和过滤功能,以及如何设置警报和通知。 Grafana中文手册还提供了关于插件和扩展的介绍,这些插件可以为Grafana增加更多的功能和样式选项。手册中还包括了一些示例和最佳实践,以帮助用户更好地使用Grafana。 总之,Grafana中文手册是一个非常有用的资源,它为用户提供了学习和使用Grafana的全面指南。无论是初学者还是有经验的用户,都可以通过它来更好地理解和使用Grafana,从而实现更好的数据可视化和监控效果。 ### 回答3: Grafana是一个开源的数据可视化工具,提供了丰富的图表和面板来展示各种数据源的信息。它支持插件扩展,可以与各种数据库和数据源集成,如Prometheus、InfluxDB、Elasticsearch等。 Grafana的中文手册提供了对该工具的详细介绍和使用说明,帮助用户快速上手和使用。手册内容包括安装和配置、面板编辑、数据源配置、警报设置等方面。 首先,手册会介绍Grafana的安装方法,包括在不同操作系统上的安装步骤和常见问题的解决方法。然后,手册会详细介绍如何配置Grafana,包括用户和权限管理、邮件和Slack通知设置等。 其次,手册会详细介绍如何编辑和创建面板。用户可以学习如何选择合适的图表类型、配置图表样式和标记、添加数据源等。手册还会介绍如何使用变量和模板,以及如何导出和导入面板配置。 另外,手册会详细介绍如何配置数据源。用户可以了解如何配置各种数据库和数据源来获取数据并显示在Grafana中。手册还会介绍如何使用查询编辑器编写和执行查询语句,以及如何配置自定义数据源。 最后,手册还会介绍如何设置警报规则,并配置邮件或Slack通知。用户可以学习如何设置报警阈值、选择接收通知的人员,并了解如何处理和解决报警事件。 总之,Grafana的中文手册提供了全面且详细的使用指南,帮助用户快速掌握该工具的各种功能和用法。无论是初学者还是有经验的用户,都可以从手册中获得帮助和指导。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值