目录
强大的性能,无限的扩展
收集、组织和处理海量高速数据。 当您将任何数据视为时间序列数据时,它会更有价值。 使用 InfluxDB,这是排名第一的时间序列平台,旨在与 Telegraf 一起扩展。
查看入门方法
输入和输出集成概述
DNS 插件使用户能够监控和收集 DNS 查询时间的统计信息,从而促进 DNS 解析的性能分析。
此插件使用参数化的 SQL INSERT 语句将 Telegraf 中的指标直接写入 MariaDB,从而提供了一种将指标存储在结构化关系表中的灵活方法。
集成详情
DNS
此插件以毫秒为单位收集 DNS 查询时间,利用类似于 Dig 命令的 DNS 查询功能。 它提供了一种监控和分析 DNS 性能的方法,通过测量来自指定 DNS 服务器的响应时间,使网络管理员和工程师能够确保最佳 DNS 解析时间。 该插件可以配置为针对特定服务器并自定义查询的记录类型,涵盖各种 DNS 功能,例如将域名解析为 IP 地址,或根据需要从特定记录中检索详细信息,同时还清楚地报告每次查询的成功或失败,以及相关的元数据。
MariaDB
Telegraf 中的 SQL 输出插件允许通过执行参数化的 SQL 语句将指标直接写入与 SQL 兼容的数据库(如 MariaDB)。 通过支持 MySQL 驱动程序,该插件与 MariaDB 无缝集成,以实现可靠的结构化指标存储。 此设置非常适合喜欢基于 SQL 的分析或希望将指标与业务数据一起存储以进行统一查询的用户。 MariaDB 是 MySQL 的一个社区开发的、企业级的分支,强调性能、安全性和开放性。 该插件支持将时间序列指标插入自定义模式,从而实现灵活的分析以及与使用 SQL 连接器的 Metabase 或 Grafana 等 BI 工具的集成。
配置
DNS
[[inputs.dns_query]]
servers = ["8.8.8.8"]
# network = "udp"
# domains = ["."]
# record_type = "A"
# port = 53
# timeout = "2s"
# include_fields = []
MariaDB
[[outputs.sql]]
## Database driver
## Valid options: mssql (Microsoft SQL Server), mysql (MySQL), pgx (Postgres),
## sqlite (SQLite3), snowflake (snowflake.com) clickhouse (ClickHouse)
driver = "mysql"
## Data source name
## The format of the data source name is different for each database driver.
## See the plugin readme for details.
data_source_name = "username:password@tcp(host:port)/dbname"
## Timestamp column name
timestamp_column = "timestamp"
## Table creation template
## Available template variables:
## {TABLE} - table name as a quoted identifier
## {TABLELITERAL} - table name as a quoted string literal
## {COLUMNS} - column definitions (list of quoted identifiers and types)
table_template = "CREATE TABLE {TABLE}({COLUMNS})"
## SQL INSERT statement with placeholders. Telegraf will substitute values at runtime.
## table_template = "INSERT INTO metrics (timestamp, name, value, tags) VALUES (?, ?, ?, ?)"
## Table existence check template
## Available template variables:
## {TABLE} - tablename as a quoted identifier
table_exists_template = "SELECT 1 FROM {TABLE} LIMIT 1"
## Initialization SQL
init_sql = "SET sql_mode='ANSI_QUOTES';"
## Maximum amount of time a connection may be idle. "0s" means connections are
## never closed due to idle time.
connection_max_idle_time = "0s"
## Maximum amount of time a connection may be reused. "0s" means connections
## are never closed due to age.
connection_max_lifetime = "0s"
## Maximum number of connections in the idle connection pool. 0 means unlimited.
connection_max_idle = 2
## Maximum number of open connections to the database. 0 means unlimited.
connection_max_open = 0
## NOTE: Due to the way TOML is parsed, tables must be at the END of the
## plugin definition, otherwise additional config options are read as part of the
## table
## Metric type to SQL type conversion
## The values on the left are the data types Telegraf has and the values on
## the right are the data types Telegraf will use when sending to a database.
##
## The database values used must be data types the destination database
## understands. It is up to the user to ensure that the selected data type is
## available in the database they are using. Refer to your database
## documentation for what data types are available and supported.
#[outputs.sql.convert]
# integer = "INT"
# real = "DOUBLE"
# text = "TEXT"
# timestamp = "TIMESTAMP"
# defaultvalue = "TEXT"
# unsigned = "UNSIGNED"
# bool = "BOOL"
# ## This setting controls the behavior of the unsigned value. By default the
# ## setting will take the integer value and append the unsigned value to it. The other
# ## option is "literal", which will use the actual value the user provides to
# ## the unsigned option. This is useful for a database like ClickHouse where
# ## the unsigned value should use a value like "uint64".
# # conversion_style = "unsigned_suffix"
输入和输出集成示例
DNS
-
监控多个服务器的 DNS 性能:通过部署 DNS 插件,用户可以通过在服务器数组中指定不同的 DNS 服务器(例如 Google DNS 和 Cloudflare DNS)来同时监控它们的性能。 这种情况可以比较不同 DNS 提供商之间的响应时间和可靠性,从而有助于根据经验数据选择最佳选项。
-
分析高流量域名的查询时间:集成插件以专门测量与组织运营相关的高流量域名(例如内部服务或面向客户的站点)的响应时间。 通过关注这些域名的性能指标,组织可以主动解决延迟问题,确保服务可靠性并改善用户体验。
-
DNS 超时警报:将插件与警报系统结合使用,以便在 DNS 查询超过定义的超时阈值时通知管理员。 此设置可以帮助主动排除网络问题或服务器配置错误,从而对潜在的停机情况做出快速响应。
-
收集历史数据以了解性能趋势:使用插件收集较长时期内 DNS 查询时间的历史数据。 此数据可用于分析 DNS 性能的趋势和模式,从而更好地进行容量规划、识别周期性问题,并为基础设施升级或更改 DNS 架构提供依据。
MariaDB
-
商业智能集成:将应用程序性能指标直接存储到 MariaDB 中,并将其连接到 Metabase 或 Apache Superset 等 BI 工具。 此设置允许将运营数据与业务 KPI 混合,以实现统一的仪表板,从而提高跨部门的可见性。
-
使用历史指标进行合规性报告:使用此插件将指标记录到 MariaDB 中,用于审计和合规性用例。 关系模型支持使用带时间戳的条目精确查询过去的绩效指标,从而支持监管文档。
-
基于 SQL 逻辑的自定义警报:将指标插入 MariaDB 并使用自定义 SQL 查询来定义警报阈值或条件。 结合 cron 作业或计划脚本,这可以实现传统指标平台无法实现的高级警报工作流程。
-
物联网传感器指标存储:通过 Telegraf 收集来自物联网设备的传感器数据,并使用规范化的模式将其存储在 MariaDB 中。 这种方法经济高效,并且可以很好地与现有的基于 SQL 的系统集成,用于实时或历史分析。
反馈
感谢您成为我们社区的一份子! 如果您有任何一般性反馈或在这些页面上发现了任何错误,我们欢迎并鼓励您提供意见。 请在 InfluxDB 社区 Slack 中提交您的反馈。
强大的性能,无限的扩展
收集、组织和处理海量高速数据。 当您将任何数据视为时间序列数据时,它会更有价值。 使用 InfluxDB,这是排名第一的时间序列平台,旨在与 Telegraf 一起扩展。
查看入门方法