PHP OpenTracing + Jaeger: сервис не отображается в Jaeger

Я пытался внедрить OpenTracing + Jaeger в свой проект PHP, следуя примеру «Начало работы» там https://github.com/jonahgeorge/jaeger-client-php

Трассировщик, диапазоны и области были созданы успешно, но Джагер не видит мою службу.

Ниже приведены мои файлы .php и docker-compose.yml:

<?php

require_once __DIR__ . '/vendor/autoload.php';

use Jaeger\Config;
use OpenTracing\GlobalTracer;

class OpenTracing
{
    public function __construct()
    {
            $config = new Config(
                [
                    'sampler' => [
                        'type' => 'const',
                        'param' => true,
                    ],
                    'logging' => true,
                    'local_agent' => [
                        'reporting_host' => 'localhost',
                        'reporting_port' => 5775
                    ]
                ],
                'test.service'
            );
            $config->initializeTracer();

            $tracer = GlobalTracer::get();

            $parent = $tracer->startActiveSpan('parent');
            sleep(1);
            $child = $tracer->startActiveSpan('child');
            $child->close();
            sleep(3);
            $parent->close();
    }
}
version: '3'
services:
  jaeger:
    image: jaegertracing/all-in-one:1.6
    container_name: as-jaeger
    ports:
      - "5775:5775/udp"
      - "6831:6831/udp"
      - "6832:6832/udp"
      - "5778:5778"
      - "16686:16686"
      - "14268:14268"
      - "9411:9411"
    environment:
      - COLLECTOR_ZIPKIN_HTTP_PORT=9411

person m m    schedule 17.09.2019    source источник


Ответы (1)


«Report_host» должен быть не «localhost», а «jaeger», как и вызывается служба в docker-compose.yml. 'reporting_host' => 'jaeger',

Кроме того, мне нужно было добавить $tracer->flush();, в конце концов, он закрывает все сущности и выполняет отправку через UDP за кулисами.

person m m    schedule 18.09.2019