【问题标题】:OpenTelemetry Collector 404'ing at http://localhost:55681/v1/tracesOpenTelemetry Collector 404'ing at http://localhost:55681/v1/traces
【发布时间】:2021-10-03 17:55:39
【问题描述】:

我已经浏览了官方的 Otel 收集器文档,并使用 Docker 和以下配置/代码文件运行收集器,但是当应用程序尝试 POST 到 /v1/traces 时,总是从收集器获得 404端点。我还尝试了各种代码示例this post,在 macOS 和 Ubuntu 上运行收集器,使用旧版本,但都没有成功。甚至curl -s -X POST 'http://localhost:55681/v1/traces 也给出了 404。这不再是正确的端点吗?它一定很简单。 :)

docker run -it --rm -p 13133:13133 -p 14250:14250 -p 14268:14268 -p 55678-55681:55678-55681 -p 4317:4317 -p 8888:8888 -p 9411:9411 --name opentelemetry-collector -v "${PWD}/collector.yaml":/collector.yaml otel/opentelemetry-collector --config collector.yaml

collector.yaml

receivers:
  otlp:
    protocols:
      grpc:
      http:

processors:
  batch:

exporters:
  otlp:
    endpoint: 0.0.0.0:4317
  jaeger:
    endpoint: 0.0.0.0:14250

extensions:
  health_check:
  pprof:
  zpages:

service:
  extensions: [health_check, pprof, zpages]
  pipelines:
    traces:
      receivers: [otlp]
      processors: [batch]
      exporters: [otlp]
    metrics:
      receivers: [otlp]
      processors: [batch]
      exporters: [otlp]
    logs:
      receivers: [otlp]
      processors: [batch]
      exporters: [otlp]

Angular 应用中的 TypeScript

import { Injectable } from '@angular/core';
import { JaegerExporter, ExporterConfig } from '@opentelemetry/exporter-jaeger';
import { WebTracerProvider } from '@opentelemetry/web';
import { SimpleSpanProcessor, ConsoleSpanExporter } from '@opentelemetry/tracing';
import { CollectorExporterNodeConfigBase, CollectorTraceExporter } from '@opentelemetry/exporter-collector';

@Injectable({
  providedIn: 'root'
})
export class TracerService {

  public tracerProvider: WebTracerProvider;

  constructor() {
    this.tracerProvider = new WebTracerProvider();
    this.tracerProvider.addSpanProcessor(new SimpleSpanProcessor(new ConsoleSpanExporter()));

    let conf: CollectorExporterNodeConfigBase = {};
    const exporter = new CollectorTraceExporter(conf);
    this.tracerProvider.addSpanProcessor(new SimpleSpanProcessor(exporter));
    this.tracerProvider.register();
  }
}

普罗米修斯.yaml

global:
  scrape_interval: 15s # Default is every 1 minute.

scrape_configs:
  - job_name: 'collector'
    # metrics_path defaults to '/metrics'
    # scheme defaults to 'http'.
    static_configs:
      - targets: ['collector:9464']

【问题讨论】:

标签: angular prometheus opentracing open-telemetry opencensus


【解决方案1】:

问题一定是收集器本身的问题,因为它工作了很长时间,请检查最新版本,它仍然会发生。 一些解释以更好地理解问题: Web 的导出器收集器使用 2 种方法发送跟踪,一种是 sendBeacon,其次是 XMLHttpRequest。只有在未定义标头并且当然信标可用时才会使用信标。作为一种解决方法,您可以尝试定义空标头,例如应该足以从信标切换到 XMLHttpRequest

const exporter = new CollectorTraceExporter({headers: {}});

这种方式将使用 XMLHttpRequest,它的默认内容类型设置为“application/json”

【讨论】:

  • 不幸的是,这也不起作用,也不适用于以前的收集器版本。你有一个适用于当前版本的 curl 示例吗?
猜你喜欢
  • 2020-08-22
  • 2023-01-18
  • 1970-01-01
  • 2021-09-14
  • 2015-12-04
  • 1970-01-01
  • 2022-12-07
  • 1970-01-01
  • 2023-01-28
相关资源
最近更新 更多