-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathDockerfile
66 lines (55 loc) · 3.79 KB
/
Dockerfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
# Example quickstart Dockerfile:
# - Spring petclinic: https://github.com/spring-projects/spring-petclinic
# - Grafana Cloud OTLP Gateway: https://github.com/grafana/grafana-opentelemetry-java#grafana-cloud-otlp-gateway
# For production, use Dockerfile.production instead.
# Use renovate to keep the version up-to-date
# renovate: datasource=github-releases depName=grafana-opentelemetry-java packageName=grafana/grafana-opentelemetry-java
ARG GRAFANA_OPENTELEMETRY_VERSION=2.12.0
FROM us-docker.pkg.dev/grafanalabs-global/docker-grafana-opentelemetry-java-prod/grafana-opentelemetry-java:$GRAFANA_OPENTELEMETRY_VERSION AS agent
FROM springio/petclinic
# 1. Sign in to Grafana Cloud (https://grafana.com), register for a Free Grafana Cloud account if required.
#
# 2. After successful login, the browser will navigate to the Grafana Cloud Portal page https://grafana.com/profile/org.
#
# A new account will most likely belong to one organization with one stack.
#
# If the account has access to multiple Grafana Cloud Organizations, select an organization from the top left **organization dropdown**.
#
# If the organization has access to multiple Grafana Cloud Stacks, navigate to a stack from the **left side bar** or the main **Stacks** list.
#
# 3. With a stack selected, or in the single stack scenario, below **Manage your Grafana Cloud Stack**, click **Configure** in the **OpenTelemetry** section.
#
# 4. In the **Password / API Token** section, click on **Generate now** to create a new API token:
# - Give the API token a name, for example `otel-java`
# - Click on **Create token**
# - Click on **Close** without copying the token
# - Now the environment variables section is populated with all the necessary information to send telemetry data to Grafana Cloud
# - Click on **Copy to Clipboard** to and replace the three lines below, replacing "export " with "ENV " (without the quotes)
ENV OTEL_EXPORTER_OTLP_PROTOCOL="http/protobuf"
ENV OTEL_EXPORTER_OTLP_ENDPOINT="https://otlp-gateway-prod-eu-west-0.grafana.net/otlp"
ENV OTEL_EXPORTER_OTLP_HEADERS="Authorization=Basic secret"
# 5. Come up with a **Service Name** to identify the service, for example `cart`, and copy it into the shell command below.
# Use the `service.namespace` to group multiple services together.
ENV OTEL_SERVICE_NAME=<Service Name>
# 6. Optional: add resource attributes to the shell command below:
# - **deployment.environment**: Name of the deployment environment, for example `staging` or `production`
# - **service.namespace**: A namespace to group similar services, for example using `service.namespace=shop` for a `cart`
# and `fraud-detection` service would create `shop/cart` and `shop/fraud-detection` in
# Grafana Cloud Application Observability with filtering capabilities for easier management
# - **service.version**: The application version, to see if a new version has introduced a bug
# - **service.instance.id**: The unique instance, for example the Pod name (a UUID is generated by default)
#
# ENV OTEL_RESOURCE_ATTRIBUTES=deployment.environment=<Environment>,service.namespace=<Namespace>,service.version=<Version>
# Build and run the application:
# 7. docker build -t grafana_opentelemetry_java_demo .
# 8. docker run -p 8080:8080 grafana_opentelemetry_java_demo
# 9. Open <http://localhost:8080> in your browser
# 10. Click on "Error" in the top right corner to generate an error
# 11. Open Application Observability in Grafana Cloud:
# - Click on the menu icon in the top left corner
# - Open the "Observability" menu
# - Click on "Application"
# Note: It might take up to five minutes for data to appear.
WORKDIR /app/
COPY --from=agent --chown=cnb /javaagent.jar /app/javaagent.jar
ENV JAVA_TOOL_OPTIONS=-javaagent:/app/javaagent.jar