From eeefe9d26fd340876d3bb25ac2f970d448e4f219 Mon Sep 17 00:00:00 2001 From: Vincent Emonet Date: Fri, 22 Dec 2023 12:48:51 +0100 Subject: [PATCH] improve otel --- src/trapi_predict_kit/trapi.py | 11 ++++++----- tests/conftest.py | 2 ++ 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/src/trapi_predict_kit/trapi.py b/src/trapi_predict_kit/trapi.py index 71b0e24..62a4fa3 100644 --- a/src/trapi_predict_kit/trapi.py +++ b/src/trapi_predict_kit/trapi.py @@ -58,7 +58,7 @@ def __init__( title="Translator Reasoner API", version="1.0.0", openapi_version="3.0.1", - add_opentelemetry=False, + opentelemetry=False, description="""Get predicted targets for a given entity \n\nService supported by the [NCATS Translator project](https://ncats.nih.gov/translator/about)""", **kwargs: Any, @@ -72,6 +72,9 @@ def __init__( root_path_in_servers=False, **kwargs, ) + if itrb_url_prefix and opentelemetry and not os.environ.get("NO_JAEGER"): + add_opentelemetry(self, itrb_url_prefix) + self.predict_endpoints = predict_endpoints self.info = info self.infores = self.info.get("x-translator", {}).get("infores") @@ -84,9 +87,6 @@ def __init__( # On ITRB deployment and local dev we directly use the current server self.servers = [] - if itrb_url_prefix and add_opentelemetry and not os.environ.get("NO_JAEGER"): - add_opentelemetry(self, itrb_url_prefix) - # For the API deployed on our server and registered to SmartAPI we provide the complete list if os.getenv("VIRTUAL_HOST"): if itrb_url_prefix: @@ -279,7 +279,7 @@ def openapi(self) -> Dict[str, Any]: return self.openapi_schema -def add_opentelemetry(app: TRAPI, service_name: str) -> None: +def add_opentelemetry(app: FastAPI, service_name: str) -> None: """Configure Open Telemetry https://github.com/ranking-agent/aragorn/blob/main/src/otel_config.py#L4 https://ncatstranslator.github.io/TranslatorTechnicalDocumentation/deployment-guide/monitoring/ @@ -305,6 +305,7 @@ def add_opentelemetry(app: TRAPI, service_name: str) -> None: warnings.filterwarnings("ignore", category=ResourceWarning) trace.set_tracer_provider(TracerProvider(resource=Resource.create({SERVICE_NAME: service_name}))) jaeger_host = os.environ.get("JAEGER_HOST", "jaeger-otel-agent.sri") + # jaeger_host = os.environ.get("JAEGER_HOST", "localhost") jaeger_port = int(os.environ.get("JAEGER_PORT", "6831")) jaeger_exporter = JaegerExporter( agent_host_name=jaeger_host, diff --git a/tests/conftest.py b/tests/conftest.py index 32c6e9e..943e37c 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -90,4 +90,6 @@ def get_predictions(request: PredictInput) -> PredictOutput: \n\nService supported by the [NCATS Translator project](https://ncats.nih.gov/translator/about)""", itrb_url_prefix="openpredict", dev_server_url="https://openpredict.semanticscience.org", + # opentelemetry=True, + # docker run -d --name jaeger -p 16686:16686 -p 6831:6831/udp jaegertracing/all-in-one:latest )