目录
输入和输出集成概述
Salesforce Telegraf 插件收集有关 Salesforce 组织中 API 使用情况和限制的关键指标,从而能够有效地监控和管理 API 消耗。
此插件使用参数化的 SQL INSERT 语句将来自 Telegraf 的指标直接写入 MariaDB,从而提供了一种灵活的方式,用于将指标存储在结构化的关系表中。
集成详情
Salesforce
Salesforce 插件允许用户收集关于其 Salesforce 组织内 API 使用限制和剩余使用量的指标。通过利用 Salesforce 的 REST API,特别是 limits 端点,此插件提供了关于 API 使用量已消耗多少以及剩余多少的关键见解。这对于依赖 Salesforce 进行运营的组织尤其重要,因为超出 API 限制可能会中断服务并阻碍业务流程。该插件将数据处理成结构化格式,其中包含各种 API 操作的最大值和剩余值,从而使团队更容易监控其使用情况并进行相应的计划。提供的配置允许用户自定义其凭据、环境类型(沙箱或生产)和 API 版本,从而确保在不同部署场景中的灵活性。
MariaDB
Telegraf 中的 SQL 输出插件通过执行参数化的 SQL 语句,能够将指标直接写入与 SQL 兼容的数据库(如 MariaDB)。凭借对 MySQL 驱动程序的支持,该插件与 MariaDB 无缝集成,以实现可靠、结构化的指标存储。此设置非常适合喜欢基于 SQL 的分析或希望将指标与业务数据一起存储以进行统一查询的用户。MariaDB 是一个社区开发的、企业级的 MySQL 分支,它强调性能、安全性 和开放性。该插件支持将时间序列指标插入到自定义模式中,从而可以使用 SQL 连接器灵活地进行分析以及与 Metabase 或 Grafana 等 BI 工具集成。
配置
Salesforce
[[inputs.salesforce]]
  ## specify your credentials
  ##
  username = "your_username"
  password = "your_password"
  ##
  ## (optional) security token
  # security_token = "your_security_token"
  ##
  ## (optional) environment type (sandbox or production)
  ## default is: production
  ##
  # environment = "production"
  ##
  ## (optional) API version (default: "39.0")
  ##
  # version = "39.0"
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"
输入和输出集成示例
Salesforce
- 
    监控 API 限制使用情况以进行扩展决策: 使用 Salesforce 插件跟踪 API 限制使用情况随时间的变化,并就何时扩展 Salesforce 资源做出明智的决策。通过可视化 API 消耗模式,组织可以预测高峰使用时间,从而使他们能够主动调整其基础设施或根据需要请求更高的限制。这种优化可以提高性能,并减少关键业务运营期间的停机时间。 
- 
    API 限制超出自动警报系统: 将此插件与通知系统集成,以便在 API 使用量接近临界限制时向团队发出警报。此设置不仅确保主动通知团队以防止中断,还有助于维护运营连续性和客户满意度。可以将警报配置为触发自动脚本,这些脚本可以调整负载或相应地通知利益相关者。 
- 
    多个 Salesforce 的比较分析: 利用 Salesforce 输入插件从跨不同部门或业务部门的多个 Salesforce 实例收集指标。通过集中这些数据,组织可以执行比较分析,以识别可能比其他部门更频繁地超出其 API 限制的部门。这允许进行有针对性的讨论和策略,以平衡整个组织的 API 使用量,从而实现更好的资源分配和效率。 
MariaDB
- 
    商业智能集成: 将应用程序性能指标直接存储到 MariaDB 中,并将其连接到 Metabase 或 Apache Superset 等 BI 工具。此设置允许将运营数据与业务 KPI 混合,以实现统一的仪表板,从而提高跨部门的可见性。 
- 
    使用历史指标进行合规性报告: 使用此插件将指标记录到 MariaDB 中,用于审计和合规性用例。关系模型支持使用时间戳条目精确查询过去的绩效指标,从而支持监管文档。 
- 
    基于 SQL 逻辑的自定义警报: 将指标插入 MariaDB,并使用自定义 SQL 查询来定义警报阈值或条件。与 cron 作业或计划脚本结合使用,这可以实现传统指标平台无法实现的高级警报工作流程。 
- 
    物联网传感器指标存储: 通过 Telegraf 从物联网设备收集传感器数据,并使用规范化模式将其存储在 MariaDB 中。这种方法经济高效,并且可以很好地与现有的基于 SQL 的系统集成,以进行实时或历史分析。 
反馈
感谢您成为我们社区的一份子!如果您有任何一般性反馈或在这些页面上发现任何错误,我们欢迎并鼓励您提出意见。请在 InfluxDB 社区 Slack 中提交您的反馈。