Nginx 和 MongoDB 集成

由 InfluxData 构建的开源数据连接器 Telegraf 提供支持,易于集成,性能强大。

info

这不是大规模实时查询的推荐配置。为了进行查询和压缩优化、高速摄取和高可用性,您可能需要考虑使用 Nginx 和 InfluxDB

50 亿+

Telegraf 下载量

#1

时序数据库
来源:DB Engines

10 亿+

InfluxDB 下载量

2,800+

贡献者

目录

强大的性能,无限的扩展能力

收集、组织和处理海量高速数据。当您将任何数据视为时序数据时,它会更有价值。InfluxDB 是排名第一的时序平台,旨在通过 Telegraf 进行扩展。

查看入门方法

输入和输出集成概述

Telegraf 的 Nginx 插件旨在从 Nginx Web 服务器收集状态指标,从而提供对服务器运行指标的实时洞察。

MongoDB Telegraf 插件使用户能够将指标发送到 MongoDB 数据库,自动管理时序集合。

集成详情

Nginx

此插件从 Nginx 收集状态指标。它利用 ngx_http_stub_status_module 收集与服务器性能相关的基本指标。该插件提供有关活动连接、已处理请求以及各种指标当前状态的宝贵见解。此实时数据对于监控 Web 服务器性能和确保最佳运行至关重要。配置允许用户指定 Nginx 状态端点的 URL、设置超时以及在必要时配置 TLS 设置。

MongoDB

此插件将指标发送到 MongoDB,并与其时序功能无缝集成,从而允许在时序集合尚不存在时自动创建为时序集合。它需要 MongoDB 5.0 或更高版本才能使用时序集合功能,这对于高效存储和查询基于时间的数据至关重要。此插件通过确保所有相关指标都正确存储和组织在 MongoDB 中,从而增强了监控功能,使用户能够利用 MongoDB 强大的查询和聚合功能进行时序分析。

配置

Nginx

[[inputs.nginx]]
  ## An array of Nginx stub_status URI to gather stats.
  urls = ["http://localhost/server_status"]

  ## Optional TLS Config
  # tls_ca = "/etc/telegraf/ca.pem"
  # tls_cert = "/etc/telegraf/cert.pem"
  # tls_key = "/etc/telegraf/key.pem"
  ## Use TLS but skip chain & host verification
  # insecure_skip_verify = false

  ## HTTP response timeout (default: 5s)
  response_timeout = "5s"

MongoDB

[[outputs.mongodb]]
              # connection string examples for mongodb
              dsn = "mongodb://localhost:27017"
              # dsn = "mongodb://mongod1:27017,mongod2:27017,mongod3:27017/admin&replicaSet=myReplSet&w=1"

              # overrides serverSelectionTimeoutMS in dsn if set
              # timeout = "30s"

              # default authentication, optional
              # authentication = "NONE"

              # for SCRAM-SHA-256 authentication
              # authentication = "SCRAM"
              # username = "root"
              # password = "***"

              # for x509 certificate authentication
              # authentication = "X509"
              # tls_ca = "ca.pem"
              # tls_key = "client.pem"
              # # tls_key_pwd = "changeme" # required for encrypted tls_key
              # insecure_skip_verify = false

              # database to store measurements and time series collections
              # database = "telegraf"

              # granularity can be seconds, minutes, or hours.
              # configuring this value will be based on your input collection frequency.
              # see https://docs.mongodb.com/manual/core/timeseries-collections/#create-a-time-series-collection
              # granularity = "seconds"

              # optionally set a TTL to automatically expire documents from the measurement collections.
              # ttl = "360h"

输入和输出集成示例

Nginx

  1. Web 性能监控:使用 Nginx 插件从基础设施中的各种 Nginx 服务器收集性能指标。通过在实时仪表板中可视化这些指标,团队可以跟踪性能趋势、识别瓶颈并增强 Web 应用程序的用户体验。实施此类监控使企业能够在性能问题影响最终用户之前主动解决这些问题。

  2. 负载均衡器监控:将此插件与您的负载均衡器集成,以跟踪后端 Nginx 服务器的性能。通过收集诸如“活动连接”和“已处理请求”之类的统计信息,您的运营团队可以确保流量以最佳方式流动,并且没有单个服务器过载。这种主动的负载均衡方法可以防止服务中断并增强用户体验。

  3. 自动化警报系统:将 Nginx 插件与警报服务结合使用,以便在服务器指标超出预定义阈值时自动通知您的团队。例如,如果活动连接数过高,系统可以触发警报,以便立即采取纠正措施,从而保持服务质量和可靠性。

  4. 历史数据分析:将 Nginx 插件收集的指标存储在时序数据库中,以分析历史性能趋势。此分析可以揭示高流量或低性能的时期,从而为有关基础设施扩展和优化的数据驱动决策提供依据。通过了解过去的趋势,组织可以更好地为未来的需求做好准备。

MongoDB

  1. IoT 设备动态日志记录到 MongoDB:利用此插件实时收集和存储来自大量 IoT 设备的指标。通过将设备日志直接发送到 MongoDB,您可以创建一个集中式数据库,该数据库允许轻松访问和查询运行状况指标和性能数据,从而可以根据历史趋势进行主动维护和故障排除。

  2. Web 流量时序分析:使用 MongoDB Telegraf 插件收集和分析随时间变化的 Web 流量指标。此应用程序可以帮助您了解高峰使用时间、用户交互和行为模式,从而指导营销策略和基础设施扩展决策,以改善用户体验。

  3. 自动化监控和警报系统:将 MongoDB 插件集成到跟踪应用程序性能指标的自动化监控系统中。借助时序集合,您可以根据特定阈值设置警报,使您的团队能够在潜在问题影响用户之前做出响应。这种主动管理可以提高服务可靠性和整体性能。

  4. 指标存储中的数据保留和 TTL 管理:利用 MongoDB 集合中文档的 TTL 功能来自动过期过时的指标。这对于仅最近的性能数据相关的环境尤其有用,可以防止 MongoDB 数据库因旧指标而变得混乱,并确保高效的数据管理。

反馈

感谢您成为我们社区的一份子!如果您有任何一般性反馈或在这些页面上发现了任何错误,我们欢迎并鼓励您提出意见。请在 InfluxDB 社区 Slack 中提交您的反馈。

强大的性能,无限的扩展能力

收集、组织和处理海量高速数据。当您将任何数据视为时序数据时,它会更有价值。InfluxDB 是排名第一的时序平台,旨在通过 Telegraf 进行扩展。

查看入门方法

相关集成

HTTP 和 InfluxDB 集成

HTTP 插件从一个或多个 HTTP(S) 端点收集指标。它支持各种身份验证方法和数据格式的配置选项。

查看集成

Kafka 和 InfluxDB 集成

此插件从 Kafka 读取消息,并允许根据这些消息创建指标。它支持各种配置,包括不同的 Kafka 设置和消息处理选项。

查看集成

Kinesis 和 InfluxDB 集成

Kinesis 插件允许从 AWS Kinesis 流中读取指标。它支持多种输入数据格式,并提供使用 DynamoDB 的检查点功能,以实现可靠的消息处理。

查看集成