-
Notifications
You must be signed in to change notification settings - Fork 19
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Introduce requestId MDC property #364
Changes from 1 commit
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
type: feature | ||
feature: | ||
description: Introduce a new MDC property, _requestId, that disambiguates span stacks | ||
that belong to the same traceid but are different requests. | ||
links: | ||
- https://github.com/palantir/tracing-java/pull/364 |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -136,6 +136,8 @@ final String getTraceId() { | |
return traceId; | ||
} | ||
|
||
abstract Optional<String> getRequestId(); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. We still store the request id so that it can be restored when a trace is set. However this getter is not exposed to clients of |
||
|
||
abstract Optional<String> getOriginatingSpanId(); | ||
|
||
/** Returns a copy of this Trace which can be independently mutated. */ | ||
|
@@ -195,6 +197,18 @@ boolean isObservable() { | |
return true; | ||
} | ||
|
||
@Override | ||
Optional<String> getRequestId() { | ||
if (stack.isEmpty()) { | ||
return Optional.empty(); | ||
} | ||
OpenSpan top = stack.peekFirst(); | ||
if (top.type() != SpanType.SERVER_INCOMING) { | ||
return Optional.empty(); | ||
} | ||
return Optional.of(top.getSpanId()); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think we have to pass around the value like originatingSpanId, when we create deferred traces we don't pass the full stack of spans (we don't want to allow other code to complete spans from our thread) but we still want to pass the same requestId. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Hm, but we don't do that for |
||
} | ||
|
||
@Override | ||
Optional<String> getOriginatingSpanId() { | ||
if (stack.isEmpty()) { | ||
|
@@ -220,36 +234,52 @@ private static final class Unsampled extends Trace { | |
* This allows thread trace state to be cleared when all "started" spans have been "removed". | ||
*/ | ||
private int numberOfSpans; | ||
private Optional<String> originatingSpanId = Optional.empty(); | ||
|
||
private Unsampled(int numberOfSpans, String traceId) { | ||
private Optional<String> originatingSpanId; | ||
private Optional<String> requestId; | ||
|
||
private Unsampled( | ||
int numberOfSpans, | ||
String traceId, | ||
Optional<String> originatingSpanId, | ||
Optional<String> requestId) { | ||
super(traceId); | ||
this.numberOfSpans = numberOfSpans; | ||
this.originatingSpanId = originatingSpanId; | ||
this.requestId = requestId; | ||
validateNumberOfSpans(); | ||
} | ||
|
||
private Unsampled(String traceId) { | ||
this(0, traceId); | ||
this(0, traceId, Optional.empty(), Optional.empty()); | ||
} | ||
|
||
@Override | ||
void fastStartSpan(String _operation, String parentSpanId, SpanType _type) { | ||
startSpan(Optional.of(parentSpanId)); | ||
void fastStartSpan(String _operation, String parentSpanId, SpanType type) { | ||
if (numberOfSpans == 0) { | ||
originatingSpanId = Optional.of(parentSpanId); | ||
if (type == SpanType.SERVER_INCOMING) { | ||
requestId = Optional.of(Tracers.randomId()); | ||
} | ||
} | ||
numberOfSpans++; | ||
} | ||
|
||
@Override | ||
void fastStartSpan(String _operation, SpanType _type) { | ||
void fastStartSpan(String _operation, SpanType type) { | ||
if (numberOfSpans == 0 && type == SpanType.SERVER_INCOMING) { | ||
requestId = Optional.of(Tracers.randomId()); | ||
} | ||
numberOfSpans++; | ||
} | ||
|
||
@Override | ||
protected void push(OpenSpan span) { | ||
startSpan(span.getParentSpanId()); | ||
} | ||
|
||
private void startSpan(Optional<String> parentSpanId) { | ||
if (numberOfSpans == 0) { | ||
originatingSpanId = parentSpanId; | ||
originatingSpanId = span.getParentSpanId(); | ||
|
||
if (span.type() == SpanType.SERVER_INCOMING) { | ||
requestId = Optional.of(span.getSpanId()); | ||
} | ||
} | ||
numberOfSpans++; | ||
} | ||
|
@@ -267,6 +297,7 @@ Optional<OpenSpan> pop() { | |
} | ||
if (numberOfSpans == 0) { | ||
originatingSpanId = Optional.empty(); | ||
requestId = Optional.empty(); | ||
} | ||
return Optional.empty(); | ||
} | ||
|
@@ -282,14 +313,19 @@ boolean isObservable() { | |
return false; | ||
} | ||
|
||
@Override | ||
Optional<String> getRequestId() { | ||
return requestId; | ||
} | ||
|
||
@Override | ||
Optional<String> getOriginatingSpanId() { | ||
return originatingSpanId; | ||
} | ||
|
||
@Override | ||
Trace deepCopy() { | ||
return new Unsampled(numberOfSpans, getTraceId()); | ||
return new Unsampled(numberOfSpans, getTraceId(), getOriginatingSpanId(), getRequestId()); | ||
} | ||
|
||
/** Internal validation, this should never fail because {@link #pop()} only decrements positive values. */ | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I had to inline the trace creation to get both the span id and the trace id out, without creating a wrapper object. Maybe just reading the MDC here is simpler?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ya, I'd prefer the minimal change where we read the requestId from MDC here.