Stackdriver 上未显示自定义 OpenCensus 指标
Custom OpenCensus metrics not appearing on Stackdriver
我正在尝试使用 OpenCensus 从我的 Go 应用程序向 Stackdriver 发送自定义指标。
我遵循了 guide,因此视图和导出器已设置:
import (
"context"
"contrib.go.opencensus.io/exporter/stackdriver"
"github.com/pkg/errors"
"go.opencensus.io/stats"
"go.opencensus.io/stats/view"
"time"
)
var (
apiRequestDurationMs = stats.Int64("api_request_duration", "API request duration in milliseconds", stats.UnitMilliseconds)
)
func NewMetricsExporter() (*stackdriver.Exporter, error) {
v := &view.View{
Name: "api_request_durations",
Measure: apiRequestDurationMs,
Description: "The distribution of request durations",
Aggregation: view.Distribution(0, 100, 200, 400, 1000, 2000, 4000),
}
if registerError := view.Register(v); registerError != nil {
return nil, errors.Wrapf(registerError, "failed to register request duration view")
}
exporter, exporterError := stackdriver.NewExporter(stackdriver.Options{ProjectID: "project-ID"})
if exporterError != nil {
return nil, errors.Wrapf(exporterError, "failed to create stackdriver exporter")
}
if startError := exporter.StartMetricsExporter(); startError != nil {
return nil, errors.Wrapf(startError, "failed to create stackdriver exporter")
}
return exporter, nil
}
然后我使用以下方式发送我的指标:
func RequestDuration(d time.Duration) {
stats.Record(context.Background(), apiRequestDurationMs.M(int64(d)))
}
但是我发送的自定义指标没有出现在 Stackdriver 的 Metrics Explorer 中。
我错过了什么?
问题出在用户指南中。
事实上,您必须注册出口商并设置报告间隔:
view.RegisterExporter(exporter)
view.SetReportingPeriod(60 * time.Second)
我正在尝试使用 OpenCensus 从我的 Go 应用程序向 Stackdriver 发送自定义指标。
我遵循了 guide,因此视图和导出器已设置:
import (
"context"
"contrib.go.opencensus.io/exporter/stackdriver"
"github.com/pkg/errors"
"go.opencensus.io/stats"
"go.opencensus.io/stats/view"
"time"
)
var (
apiRequestDurationMs = stats.Int64("api_request_duration", "API request duration in milliseconds", stats.UnitMilliseconds)
)
func NewMetricsExporter() (*stackdriver.Exporter, error) {
v := &view.View{
Name: "api_request_durations",
Measure: apiRequestDurationMs,
Description: "The distribution of request durations",
Aggregation: view.Distribution(0, 100, 200, 400, 1000, 2000, 4000),
}
if registerError := view.Register(v); registerError != nil {
return nil, errors.Wrapf(registerError, "failed to register request duration view")
}
exporter, exporterError := stackdriver.NewExporter(stackdriver.Options{ProjectID: "project-ID"})
if exporterError != nil {
return nil, errors.Wrapf(exporterError, "failed to create stackdriver exporter")
}
if startError := exporter.StartMetricsExporter(); startError != nil {
return nil, errors.Wrapf(startError, "failed to create stackdriver exporter")
}
return exporter, nil
}
然后我使用以下方式发送我的指标:
func RequestDuration(d time.Duration) {
stats.Record(context.Background(), apiRequestDurationMs.M(int64(d)))
}
但是我发送的自定义指标没有出现在 Stackdriver 的 Metrics Explorer 中。
我错过了什么?
问题出在用户指南中。 事实上,您必须注册出口商并设置报告间隔:
view.RegisterExporter(exporter)
view.SetReportingPeriod(60 * time.Second)