【问题标题】:Problems parsing JSON with Telegraf使用 Telegraf 解析 JSON 时出现问题
【发布时间】:2025-11-26 10:20:04
【问题描述】:

我想使用 Telegraf 从 swagger API 收集数据

这是我的 telegraf.conf 中的 DS 定义

[[inputs.httpjson]]
  ## NOTE This plugin only reads numerical measurements, strings and booleans
  ## will be ignored.

  ## Name for the service being polled.  Will be appended to the name of the
  ## measurement e.g. "httpjson_webserver_stats".
  ##
  ## Deprecated (1.3.0): Use name_override, name_suffix, name_prefix instead.
  name = "ultimaker_status"

  ## URL of each server in the service's cluster
  servers = [
    "http://192.168.5.15/api/v1/printer/network",
  ]
  ## Set response_timeout (default 5 seconds)
  response_timeout = "15s"

  ## HTTP method to use: GET or POST (case-sensitive)
  method = "GET"

  ## Tags to extract from top-level of JSON server response.
   tag_keys = [
     "ethernet:connected"
   ]

  ## 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 Request Parameters (all values must be strings).  For "GET" requests, data
  ## will be included in the query.  For "POST" requests, data will be included
  ## in the request body as "x-www-form-urlencoded".
  # [inputs.httpjson.parameters]
  #   event_type = "cpu_spike"
  #   threshold = "0.75"

  ## HTTP Request Headers (all values must be strings).
  # [inputs.httpjson.headers]
  #   X-Auth-Token = "my-xauth-token"
  #   apiVersion = "v1"

http://192.168.5.15/api/v1/printer/network的HTTP请求返回以下字符串

{"ethernet": {"connected": true, "enabled": true}, "wifi": {"connected": false, "enabled": false, "mode": "CABLE", "ssid" : "UM-NO-HOTSPOT-NAME-SET"}, "wifi_networks": []}

Telegraf --test 返回以下内容

httpjson_ultimaker_status,host=dmon-virtual-machine,server=http://192.168.5.15/api/v1/printer/network response_time=7.333277032 1551105770000000000

我希望字符串“已连接”不是 1551105770000000000

我怎样才能得到预期的结果

感谢您的帮助

【问题讨论】:

    标签: json http swagger telegraf


    【解决方案1】:

    在带有 json 插件的块开头的 telegraf.conf 文件中,它说:
    “注意这个插件只读取数值测量,字符串和布尔值将被忽略。”

    【讨论】:

      【解决方案2】:

      除非在 tag_key 或 json_string_fields 选项中指定,否则 JSON 字符串将被忽略。

      也许你可以试试,比如

      tag_keys = ["ethernet_connected"] json_string_fields = ["ethernet_connected"]

      您可以在以下位置找到更多信息 https://github.com/influxdata/telegraf/tree/master/plugins/parsers/json

      【讨论】: