You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
MDC API should always be used within the try/finally statement:
private static final Logger LOG = ...
public ... process(Order order) throws ... {
try {
MDC.put("order", order.getId());
MDC.put("customer", order.getCustomerId());
LOG.debug("Order {} initiated for {}", order.geId(), order.getCustomerId());
// .. business logic
} finally {
MDC.remove("order");
MDC.remove("customer");
}
return ...
}
If an exception happens and the developer isn't using the finally statement the thread-local value might not be cleaned and we'll have thread pollution.
reacted with thumbs up emoji reacted with thumbs down emoji reacted with laugh emoji reacted with hooray emoji reacted with confused emoji reacted with heart emoji reacted with rocket emoji reacted with eyes emoji
-
Summary
Why?
MDC API should always be used within the try/finally statement:
If an exception happens and the developer isn't using the
finally
statement the thread-local value might not be cleaned and we'll have thread pollution.Beta Was this translation helpful? Give feedback.
All reactions