1

我正在使用jsonnet在 Grafana 中配置我的面板。我是第一次使用它,我非常喜欢它。但是,我很难理解某些方面。

我有类似以下内容:

.addTemplate(
  template.new(
    microservices,
    datasource='',
    query=std.join(',', std.map(function(x) x.text, service['microservices'])),
    label= services,
  )

我现在要做的是获取给定微服务的位置,以便能够将其分配给变量服务(然后通过query=std.join(',', std.map(function(x) x.text, service['microservices'])), )。

local services = std.extVar('services');
local service = services[x?];

变量服务具有以下形式:

[
  {
    // I'm trying to get this array position where my value is
    "key": "asd",
    "microservices": [
      {
        "key": "I HAVE THIS VALUE",
        "text": "ads"
      },
      {
        "key": "asd",
        "text": "ads"
      },
      {
        "key": "asd",
        "text": "asd"
      }
    ],
    "name": "bca",
    "services: [
      {
        "key": "bca",
        "name": "bca"
      }
    ]
  },
  {
    "key": "bca",
    "microservices": [
      {
        "key": "bca",
        "text": "bca"
      },
      {
        "key": "bca",
        "text": "bca"
      }
    ],
    "name": "bca",
    "services: [
      {
        "key": "bca",
        "name": "bca"
      }
    ]
  },
  {
    "key": "abc",
    "microservices": [
      {
        "key": "bca",
        "text": "bca"
      }
    ],
    "name": "abc",
    "services: [
      {
        "key": "ccc",
        "name": "ccc"
      }
    ]
  }
]

在我看来,在任何其他语言中,这似乎都是一个非常基本的操作。

var srv type
for x, service := range services{
  for _, microservice := range service.microservices{
    if microservice.key == "my value"{
      srv= services[x]
    }
}

任何提示?

太感谢了。

4

1 回答 1

3

在 Jsonnet 中也是一个非常简单的操作。最自然的方法是使用数组推导,它也方便地支持过滤:

local service2 = [
    s for s in services
    if [ms for ms in s.microservices if ms.key == "I HAVE THIS VALUE"] != []
][0];

请注意索引[0]- 通常可能有不止一种匹配服务或没有匹配服务。所以如果你想得到第一个,你需要明确地接受它。

上面的代码是在假设您不关心实际索引的情况下编写的,您只想检索此服务。如果你需要它,它会变得有点复杂:

local serviceIndex = [
  x for x in std.range(0, std.length(services) - 1)
  if [ms for ms in services[x].microservices if ms.key == "I HAVE THIS VALUE"] != []
][0];

顺便说一句,您可以使用诸如 之类的函数来获得相同的结果std.filter,但这会更加冗长。

BTW2 我也会考虑提取一个函数hasMicroservice(service, msKey)来增强过滤的可读性。

于 2019-11-10T21:54:53.493 回答