From 194a90704fc889ecd94cebf2a8b7b926a5aeab03 Mon Sep 17 00:00:00 2001 From: Gaurav Vaidya Date: Mon, 4 Nov 2024 16:24:36 -0500 Subject: [PATCH] Updated OTEL to use gRPC instead of Jaeger. Based on the changes made at https://github.com/TranslatorSRI/NodeNormalization/pull/298 --- api/server.py | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/api/server.py b/api/server.py index 748a76fb..6362ea6b 100755 --- a/api/server.py +++ b/api/server.py @@ -495,7 +495,7 @@ async def lookup(string: str, if os.environ.get('OTEL_ENABLED', 'false') == 'true': from opentelemetry.instrumentation.fastapi import FastAPIInstrumentor from opentelemetry import trace - from opentelemetry.exporter.jaeger.thrift import JaegerExporter + from opentelemetry.exporter.otlp.proto.grpc.trace_exporter import OTLPSpanExporter from opentelemetry.sdk.resources import SERVICE_NAME, Resource from opentelemetry.sdk.trace import TracerProvider from opentelemetry.sdk.trace.export import BatchSpanProcessor @@ -508,19 +508,19 @@ async def lookup(string: str, # these supresses such warnings. logging.captureWarnings(capture=True) warnings.filterwarnings("ignore", category=ResourceWarning) - plater_service_name = os.environ.get('SERVER_NAME', 'infores:sri-name-resolver') - assert plater_service_name and isinstance(plater_service_name, str) - - jaeger_exporter = JaegerExporter( - agent_host_name=os.environ.get("JAEGER_HOST", "localhost"), - agent_port=int(os.environ.get("JAEGER_PORT", "6831")), - ) - resource = Resource(attributes={ - SERVICE_NAME: os.environ.get("JAEGER_SERVICE_NAME", plater_service_name), + otel_service_name = os.environ.get('SERVER_NAME', 'infores:sri-node-normalizer') + assert otel_service_name and isinstance(otel_service_name, str) + + otlp_host = os.environ.get("JAEGER_HOST", "http://localhost/").rstrip('/') + otlp_port = os.environ.get("JAEGER_PORT", "4317") + otlp_endpoint = f'{otlp_host}:{otlp_port}' + otlp_exporter = OTLPSpanExporter(endpoint=f'{otlp_endpoint}') + processor = BatchSpanProcessor(otlp_exporter) + # processor = BatchSpanProcessor(ConsoleSpanExporter()) + resource = Resource.create(attributes={ + SERVICE_NAME: os.environ.get("JAEGER_SERVICE_NAME", otel_service_name), }) provider = TracerProvider(resource=resource) - # processor = BatchSpanProcessor(ConsoleSpanExporter()) - processor = BatchSpanProcessor(jaeger_exporter) provider.add_span_processor(processor) trace.set_tracer_provider(provider) FastAPIInstrumentor.instrument_app(app, tracer_provider=provider, excluded_urls=