loki:“错误每个流至少需要一个标签对”

Posted

技术标签:

【中文标题】loki:“错误每个流至少需要一个标签对”【英文标题】:loki: "error at least one label pair is required per stream" 【发布时间】:2021-12-16 23:20:56 【问题描述】:

我根据these instructions在docker本地运行loki、pomtrail、grafana

当我尝试运行以下测试以直接向 loki 发送数据时:

curl -i -H "Content-type: application/json" -X POST --data ' "streams": [  "labels":  "job": "randomjob" , "entries": [ "ts": "2021-10-12T16:13:06.801064Z", "line": "TEST!" ]  ] ' http://localhost:3100/loki/api/v1/push

我得到错误:

HTTP/1.1 400 Bad Request
Content-Type: text/plain; charset=utf-8
X-Content-Type-Options: nosniff
Date: Tue, 02 Nov 2021 12:09:26 GMT
Content-Length: 53

error at least one label pair is required per stream

为什么找不到标签? 谢谢。

【问题讨论】:

【参考方案1】:

标签对的格式应该是(对于旧端点/api/prom/push)并且它有效:

"labels": "job=\"randomjob\""

例如:

curl -H "Content-Type: application/json" -XPOST -s "172.30.11.21:3100/api/prom/push" --data-raw   '"streams": [
   
      "labels": "job=\"randomjob\"", 
      "entries": [
           
              "ts": "2021-11-13T19:55:51.801064-00:00", 
              "line": "TEST!" 
          
      ] 
  
]

'

对于新端点/loki/api/v1/push,似乎需要将labels 字段更改为stream

curl -H "Content-Type: application/json" -XPOST -s "172.30.11.21:3100/loki/api/v1/push" --data-raw '"streams": [ "stream": "job": "randomjob", "values": [["1636841990000000000",  "TEST!" ]] ] ]'

【讨论】:

天哪,修复了它。所以我只需要反斜杠??!我现在收到一个新错误loghttp.PushRequest.Streams: []*loghttp.Stream: Skip: do not know how to skip: 92, error found in #10 byte of ...,但这清楚地修复了标签对错误,所以接受答案! 嗯,是的,对于旧端点,您需要使用 labels 值作为单个字符串,除了它包含 json-object,然后您需要转义内部双引号。对于新端点,字段不同:streamvalues

以上是关于loki:“错误每个流至少需要一个标签对”的主要内容,如果未能解决你的问题,请参考以下文章

洛基(Loki)运行游戏出现问题需要关闭

MongoDB 存储的 Loki 配置

如何使用 Loki 的小对象分配器?

Kubernetes日志系统新贵Loki-Stack

loki搭建记录

Loki 保留期 s3 + dynamo