【问题标题】:Can't get custom metrics data when using OpenCensus使用 OpenCensus 时无法获取自定义指标数据
【发布时间】:2020-12-21 05:49:01
【问题描述】:

我正在关注本指南monitoring_opencensus_metrics_quickstart-go。另外,我也尝试了这个answer的方式。

代码在这里:

package main

import (
    "context"
    "fmt"
    "log"
    "os"
    "path"
    "time"

    "google.golang.org/api/option"

    "contrib.go.opencensus.io/exporter/stackdriver"
    "go.opencensus.io/stats"
    "go.opencensus.io/stats/view"
    "golang.org/x/exp/rand"
)

var (
    // The task latency in milliseconds.
    latencyMs = stats.Float64("task_latency", "The task latency in milliseconds", "ms")
)

func main() {
    ctx := context.Background()
    v := &view.View{
        Name:        "task_latency_distribution",
        Measure:     latencyMs,
        Description: "The distribution of the task latencies",
        Aggregation: view.Distribution(0, 100, 200, 400, 1000, 2000, 4000),
    }
    if err := view.Register(v); err != nil {
        log.Fatalf("Failed to register the view: %v", err)
    }

    exporter, err := stackdriver.NewExporter(stackdriver.Options{
        ProjectID: os.Getenv("GOOGLE_CLOUD_PROJECT"),
        MonitoringClientOptions: []option.ClientOption{
            option.WithCredentialsFile(path.Join("./.gcp/stackdriver-monitor-admin.json")),
        },
    })
    if err != nil {
        log.Fatal(err)
    }
    view.RegisterExporter(exporter)
    view.SetReportingPeriod(60 * time.Second)
    // Flush must be called before main() exits to ensure metrics are recorded.
    defer exporter.Flush()

    if err := exporter.StartMetricsExporter(); err != nil {
        log.Fatalf("Error starting metric exporter: %v", err)
    }
    defer exporter.StopMetricsExporter()

    // Record 100 fake latency values between 0 and 5 seconds.
    for i := 0; i < 100; i++ {
        ms := float64(5*time.Second/time.Millisecond) * rand.Float64()
        fmt.Printf("Latency %d: %f\n", i, ms)
        stats.Record(ctx, latencyMs.M(ms))
        time.Sleep(1 * time.Second)
    }

    fmt.Println("Done recording metrics")
}

我在本地运行上面的代码,而不是在 GCE、GAE 和 GKE 环境中。

在metrics explorer web UI,这里是metric查询条件:

  • 资源类型:Consumed API
  • 公制:custom.googleapis.com/opencensus/task_latency_distribution

完整查询:

fetch consumed_api
| metric 'custom.googleapis.com/opencensus/task_latency_distribution'
| align delta(1m)
| every 1m
| group_by [],
    [value_task_latency_distribution_aggregate:
       aggregate(value.task_latency_distribution)]

服务帐户具有Monitoring Admin 角色。

但是得到了No data is available for the selected time frame

【问题讨论】:

  • 您是否再次确认所有这些steps 都已得到处理?
  • @AartiS 当然。 opencensus 和云跟踪服务工作正常,但云监控不起作用,如问题中所述
  • 我认为对于这种行为,最好向谷歌(cloud.google.com/support/docs)开一个支持案例,这样很容易得到答案。

标签: google-cloud-platform stackdriver google-cloud-stackdriver google-cloud-monitoring opencensus


【解决方案1】:

它对我有用,但我倾向于做一些不同的事情:

  • export GOOGLE_APPLICATION_CREDENTIALS=path/to/creds 而不是 MonitoringClientOptions{};
  • 以前(!?)我在使用 0 存储桶的分布时遇到问题;尝试删除初始 (0) 存储桶并重试;
  • 从指标资源管理器中删除resource.type;来自 APIs Explorer,如果有的话,这应该是 global

Google APIs Explorer 是诊断 Stackdriver API 挑战的绝佳方式。您可以使用它来列出指标和时间序列(替换 your-project-id 并更新 2 个 interval 值):

https://cloud.google.com/monitoring/api/ref_v3/rest/v3/projects.metricDescriptors/list?apix=true&apix_params=%7B%22name%22%3A%22projects%2Fyour-project-id%22%2C%22filter%22%3A%22metric.type%3D%5C%22custom.googleapis.com%2Fopencensus%2Ftask_latency_distribution%5C%22%22%7D

https://cloud.google.com/monitoring/api/ref_v3/rest/v3/projects.timeSeries/list?apix=true&apix_params=%7B%22name%22%3A%22projects%2Fyour-project-id%22%2C%22aggregation.alignmentPeriod%22%3A%22%2B300s%22%2C%22aggregation.crossSeriesReducer%22%3A%22REDUCE_MEAN%22%2C%22aggregation.perSeriesAligner%22%3A%22ALIGN_DELTA%22%2C%22filter%22%3A%22metric.type%3D%5C%22custom.googleapis.com%2Fopencensus%2Ftask_latency_distribution%5C%22%22%2C%22interval.endTime%22%3A%222020-09-08T23%3A59%3A59Z%22%2C%22interval.startTime%22%3A%222020-09-08T00%3A00%3A00Z%22%7D

使用 Chrome 的开发者控制台,您可以找到 Stackdriver 对 API 的调用之一,以便更轻松地重现它,例如

filter: metric.type="custom.googleapis.com/opencensus/task_latency_distribution"
aggregation.crossSeriesReducer: REDUCE_MEAN
aggregation.alignmentPeriod: +60s
aggregation.perSeriesAligner: ALIGN_DELTA
secondaryAggregation.crossSeriesReducer: REDUCE_NONE
interval.startTime: 2020-09-08T23:59:59Z
interval.endTime: 2020-09-08T00:00:00Z

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2019-11-18
    • 2019-09-07
    • 1970-01-01
    • 1970-01-01
    • 2021-03-09
    • 2020-04-04
    • 2022-11-11
    • 1970-01-01
    相关资源
    最近更新 更多