This service determines appropriate ads to serve to users based on context keys. The ads will be for products available in the store.
This service relies on the OpenTelemetry Java Agent to automatically instrument
libraries such as gRPC, and to configure the OpenTelemetry SDK. The agent is
passed into the process using the -javaagent
command line argument. Command
line arguments are added through the JAVA_TOOL_OPTIONS
in the Dockerfile
,
and leveraged during the automatically generated Gradle startup script.
ENV JAVA_TOOL_OPTIONS=-javaagent:/app/opentelemetry-javaagent.jar
Within the execution of auto-instrumented code you can get current span from context.
Span span = Span.current();
Adding attributes to a span is accomplished using setAttribute
on the span
object. In the getAds
function multiples attribute are added to the span.
span.setAttribute("app.ads.contextKeys", req.getContextKeysList().toString());
span.setAttribute("app.ads.contextKeys.count", req.getContextKeysCount());
Adding an event to a span is accomplished using addEvent
on the span object.
In the getAds
function an event with an attribute is added when an exception
is caught.
span.addEvent("Error", Attributes.of(AttributeKey.stringKey("exception.message"), e.getMessage()));
If the result of the operation is an error, the span status is should be set
accordingly using setStatus
on the span object. In the getAds
function the
span status is set when an exception is caught.
span.setStatus(StatusCode.ERROR);
New spans can be created and started using
Tracer.spanBuilder("spanName").startSpan()
. Newly created spans should be set
into context using Span.makeCurrent()
. The getRandomAds
function will
create a new span, set it into context, perform an operation, and finally end
the span.
// create and start a new span manually
Tracer tracer = GlobalOpenTelemetry.getTracer("adservice");
Span span = tracer.spanBuilder("getRandomAds").startSpan();
// put the span into context, so if any child span is started the parent will be set properly
try (Scope ignored = span.makeCurrent()) {
Collection<Ad> allAds = adsMap.values();
for (int i = 0; i < MAX_ADS_TO_SERVE; i++) {
ads.add(Iterables.get(allAds, random.nextInt(allAds.size())));
}
span.setAttribute("app.ads.count", ads.size());
} finally {
span.end();
}
TBD
TBD