一、介绍
Grafana 是一个开源的数据可视化工具,它可以帮助用户将数据源中的数据进行图形化展示和实时监控,以便于用户能够更加直观地理解数据。Grafana 支持多种数据源,包括 Graphite、Elasticsearch、InfluxDB、Prometheus 等,也支持多种展示方式,如图表、仪表盘、地图、日历等。
Grafana 的主要作用包括:
- 数据可视化:通过 Grafana,用户可以将复杂的数据转化成易于理解的图表和仪表盘,并在一个界面中集中展示多个数据源的数据。
- 实时监控:Grafana 支持实时监控,可以帮助用户实时了解系统状态、性能等指标的变化情况。
- 告警与通知:Grafana 可以设置告警规则,当某些指标达到预设的阈值时,会自动发送通知,提醒用户关注和处理。
- 可扩展性:Grafana 支持插件式的开发模式,用户可以通过插件扩展功能,满足自己的特定需求。
总之,Grafana 是一款功能强大的数据可视化工具,可以帮助用户更好地理解数据,提高数据分析效率,提升工作效率。
二、数据源
Grafana 支持多种数据源,以下是其中一些主要的数据源:
- Graphite:Graphite 是一个开源的监控工具,Grafana 可以通过 Graphite 数据源将 Graphite 采集的监控数据进行可视化展示。
- Elasticsearch:Elasticsearch 是一个分布式搜索和分析引擎,Grafana 可以通过 Elasticsearch 数据源将 Elasticsearch 中的数据进行可视化展示。
- InfluxDB:InfluxDB 是一个高性能的时间序列数据库,Grafana 可以通过 InfluxDB 数据源将 InfluxDB 中的数据进行可视化展示。
- Prometheus:Prometheus 是一个开源的监控系统,Grafana 可以通过 Prometheus 数据源将 Prometheus 采集的监控数据进行可视化展示。
- MySQL:MySQL 是一个开源的关系型数据库,Grafana 可以通过 MySQL 数据源将 MySQL 数据库中的数据进行可视化展示。
- PostgreSQL:PostgreSQL 是一个开源的关系型数据库,Grafana 可以通过 PostgreSQL 数据源将 PostgreSQL 数据库中的数据进行可视化展示。
- Microsoft SQL Server:Microsoft SQL Server 是微软公司开发的一款关系型数据库管理系统,Grafana 可以通过 Microsoft SQL Server 数据源将 SQL Server 数据库中的数据进行可视化展示。
- OpenFalcon
除此之外,Grafana 还支持许多其他数据源,如 CloudWatch、OpenTSDB、MongoDB、Zabbix 等。
三、模板变量
1、案例
来源:
想配置如下效果:可以支持变量查询,选择不同的变量查询的结果不一样
步骤
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
下面对类型逐一介绍。
- Query 变量类型:
这是 Grafana 中最常用的变量类型之一,允许您从指定的数据源中检索值,并在仪表板中使用这些值。
如Prometheus配置:
如Mysql配置:https://www.jianshu.com/p/fe8bab704716
- Custom 变量类型:
自定义变量类型允许您手动指定变量的值列表。这对于需要手动指定常量列表的情况非常有用。例如,您可能需要为特定的环境或服务指定一组常量。
如下案例,多个value用逗号隔开
效果如下:
- 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
来源:
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 配置案例:
- 创建一个简单的 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)],
]
]);
?>
- 在 Grafana 中创建一个 SimpleJson 数据源,将 URL 设置为上面创建的 API 地址。例如,URL 可以是 http://example.com/random.php。
- 在 Grafana 中创建一个新的仪表盘,并添加一个图表面板。
- 在图表面板中,选择 SimpleJson 数据源,并在查询编辑器中输入查询语句。例如,可以使用类似下面的查询语句:
SELECT
UNIX_TIMESTAMP(time) as time_sec,
value
FROM
data
WHERE
$__timeFilter(time)
- 保存并刷新仪表盘,即可看到随机数的实时变化情况。
以上配置案例只是一个简单的示例,实际应用中需要根据具体的数据源和查询语句进行配置。但是,通过 SimpleJson 数据源,可以轻松地将各种数据源的数据转换为 Grafana 可以使用的格式,并进行展示和分析。
六、插件
1、介绍
grafana的插件功能很强大,本质上对接各个数据源都是通过插件开发的,比如Druid数据源插件、OpenFalcon插件,Prometheus插件等.
grafana有很多原生支持的插件,当然,我们也可以自己写插件,甚至,我们可以按照我们需求改原生的插件,比如Druid就被晓宇改过,所以下面Hubble-Druid显示Unsigned。
2、什么时候需要修改插件呢?
当数据源选项不满足我们需要的时候,我们就可以修改插件了,比如Druid插件,我们想多增加一些日期选择:
3、DeepFlow插件
在 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利用率数据,以便生成准确的火焰图。另外,生成火焰图可能需要一定的计算资源,因此在处理大量数据时,可能需要考虑优化和扩展您的计算环境。