From fd46d86a88c60ecfcc0f746af215ea19194c7bb4 Mon Sep 17 00:00:00 2001 From: Roger Coll Date: Mon, 27 May 2024 10:19:08 +0200 Subject: [PATCH] feat: add Elastic's dockerfiles for Java services --- .github/README.md | 2 +- src/adservice/Dockerfile | 5 ++- src/adservice/Dockerfile.elastic | 32 ++++++++++++++++++++ src/frauddetectionservice/Dockerfile | 7 +++-- src/frauddetectionservice/Dockerfile.elastic | 25 +++++++++++++++ 5 files changed, 65 insertions(+), 6 deletions(-) create mode 100644 src/adservice/Dockerfile.elastic create mode 100644 src/frauddetectionservice/Dockerfile.elastic diff --git a/.github/README.md b/.github/README.md index 134f0ab877..e151cf3001 100644 --- a/.github/README.md +++ b/.github/README.md @@ -3,7 +3,7 @@ The following guide describes how to setup the OpenTelemetry demo with Elastic Observability using [Docker compose](#docker-compose) or [Kubernetes](#kubernetes). This fork introduces several changes to the agents used in the demo: -- The Java agent within the [Ad](../src/adservice/Dockerfile#L27) and [Fraud Detection](../src/frauddetectionservice/Dockerfile#L21) services have been replaced with the Elastic distribution of the OpenTelemetry Java Agent. You can find more information about the Elastic distribution in [this blog post](https://www.elastic.co/observability-labs/blog/elastic-distribution-opentelemetry-java-agent). +- The Java agent within the [Ad](../src/adservice/Dockerfile.elastic) and [Fraud Detection](../src/frauddetectionservice/Dockerfile.elastic) services have been replaced with the Elastic distribution of the OpenTelemetry Java Agent. You can find more information about the Elastic distribution in [this blog post](https://www.elastic.co/observability-labs/blog/elastic-distribution-opentelemetry-java-agent). ## Docker compose diff --git a/src/adservice/Dockerfile b/src/adservice/Dockerfile index 4080f168de..a13d2b7736 100644 --- a/src/adservice/Dockerfile +++ b/src/adservice/Dockerfile @@ -20,13 +20,12 @@ RUN ./gradlew installDist -PprotoSourceDir=./proto FROM eclipse-temurin:21-jre -ARG version=0.3.2 +ARG version=2.3.0 WORKDIR /usr/src/app/ COPY --from=builder /usr/src/app/ ./ -ADD --chmod=644 https://repo1.maven.org/maven2/co/elastic/otel/elastic-otel-javaagent/$version/elastic-otel-javaagent-$version.jar /usr/src/app/opentelemetry-javaagent.jar +ADD --chmod=644 https://github.com/open-telemetry/opentelemetry-java-instrumentation/releases/download/v$version/opentelemetry-javaagent.jar /usr/src/app/opentelemetry-javaagent.jar ENV JAVA_TOOL_OPTIONS=-javaagent:/usr/src/app/opentelemetry-javaagent.jar -ENV ELASTIC_OTEL_INFERRED_SPANS_ENABLED=true EXPOSE ${AD_SERVICE_PORT} ENTRYPOINT [ "./build/install/opentelemetry-demo-ad-service/bin/AdService" ] diff --git a/src/adservice/Dockerfile.elastic b/src/adservice/Dockerfile.elastic new file mode 100644 index 0000000000..4080f168de --- /dev/null +++ b/src/adservice/Dockerfile.elastic @@ -0,0 +1,32 @@ +# Copyright The OpenTelemetry Authors +# SPDX-License-Identifier: Apache-2.0 + + +FROM eclipse-temurin:21-jdk as builder + +WORKDIR /usr/src/app/ + +COPY ./src/adservice/gradlew* ./src/adservice/settings.gradle* ./src/adservice/build.gradle ./ +COPY ./src/adservice/gradle ./gradle + +RUN ./gradlew +RUN ./gradlew downloadRepos + +COPY ./src/adservice/ ./ +COPY ./pb/ ./proto +RUN ./gradlew installDist -PprotoSourceDir=./proto + +# ----------------------------------------------------------------------------- + +FROM eclipse-temurin:21-jre + +ARG version=0.3.2 +WORKDIR /usr/src/app/ + +COPY --from=builder /usr/src/app/ ./ +ADD --chmod=644 https://repo1.maven.org/maven2/co/elastic/otel/elastic-otel-javaagent/$version/elastic-otel-javaagent-$version.jar /usr/src/app/opentelemetry-javaagent.jar +ENV JAVA_TOOL_OPTIONS=-javaagent:/usr/src/app/opentelemetry-javaagent.jar +ENV ELASTIC_OTEL_INFERRED_SPANS_ENABLED=true + +EXPOSE ${AD_SERVICE_PORT} +ENTRYPOINT [ "./build/install/opentelemetry-demo-ad-service/bin/AdService" ] diff --git a/src/frauddetectionservice/Dockerfile b/src/frauddetectionservice/Dockerfile index cf757af4ec..a2e8e00177 100644 --- a/src/frauddetectionservice/Dockerfile +++ b/src/frauddetectionservice/Dockerfile @@ -14,16 +14,19 @@ RUN gradle shadowJar FROM gcr.io/distroless/java17-debian11 +<<<<<<< HEAD <<<<<<< HEAD ARG version=2.4.0 ======= ARG version=0.3.2 >>>>>>> 4ca7109 (feat: replace Java agent with Elastic distribution) +======= +ARG version=2.3.0 +>>>>>>> 48e4547 (feat: add Elastic's dockerfiles for Java services) WORKDIR /usr/src/app/ COPY --from=builder /usr/src/app/build/libs/frauddetectionservice-1.0-all.jar ./ -ADD --chmod=644 https://repo1.maven.org/maven2/co/elastic/otel/elastic-otel-javaagent/$version/elastic-otel-javaagent-$version.jar /usr/src/app/opentelemetry-javaagent.jar +ADD --chmod=644 https://github.com/open-telemetry/opentelemetry-java-instrumentation/releases/download/v$version/opentelemetry-javaagent.jar /app/opentelemetry-javaagent.jar ENV JAVA_TOOL_OPTIONS=-javaagent:/app/opentelemetry-javaagent.jar -ENV ELASTIC_OTEL_INFERRED_SPANS_ENABLED=true ENTRYPOINT [ "java", "-jar", "frauddetectionservice-1.0-all.jar" ] diff --git a/src/frauddetectionservice/Dockerfile.elastic b/src/frauddetectionservice/Dockerfile.elastic new file mode 100644 index 0000000000..3b1c01714b --- /dev/null +++ b/src/frauddetectionservice/Dockerfile.elastic @@ -0,0 +1,25 @@ +# Copyright The OpenTelemetry Authors +# SPDX-License-Identifier: Apache-2.0 + + +FROM gradle:8-jdk17 AS builder + +WORKDIR /usr/src/app/ + +COPY ./src/frauddetectionservice/ ./ +COPY ./pb/ ./src/main/proto/ +RUN gradle shadowJar + +# ----------------------------------------------------------------------------- + +FROM gcr.io/distroless/java17-debian11 + +ARG version=0.3.2 +WORKDIR /usr/src/app/ + +COPY --from=builder /usr/src/app/build/libs/frauddetectionservice-1.0-all.jar ./ +ADD --chmod=644 https://repo1.maven.org/maven2/co/elastic/otel/elastic-otel-javaagent/$version/elastic-otel-javaagent-$version.jar /usr/src/app/opentelemetry-javaagent.jar +ENV JAVA_TOOL_OPTIONS=-javaagent:/app/opentelemetry-javaagent.jar +ENV ELASTIC_OTEL_INFERRED_SPANS_ENABLED=true + +ENTRYPOINT [ "java", "-jar", "frauddetectionservice-1.0-all.jar" ]