mirror of
https://github.com/spring-projects/spring-petclinic.git
synced 2025-07-27 09:25:49 +00:00
Add spans for cache
This commit is contained in:
parent
66e6edb849
commit
c9e5ea8c09
1 changed files with 57 additions and 0 deletions
|
@ -0,0 +1,57 @@
|
|||
package org.springframework.samples.petclinic.system;
|
||||
|
||||
import brave.Span;
|
||||
import brave.Span.Kind;
|
||||
import brave.Tracer;
|
||||
import org.aspectj.lang.ProceedingJoinPoint;
|
||||
import org.aspectj.lang.annotation.Around;
|
||||
import org.aspectj.lang.annotation.Aspect;
|
||||
import org.springframework.beans.factory.annotation.Value;
|
||||
import org.springframework.core.annotation.Order;
|
||||
import org.springframework.stereotype.Component;
|
||||
|
||||
@Aspect
|
||||
// Ordering is needed to be executed before cache interceptor
|
||||
@Order(1)
|
||||
@Component
|
||||
public class AddSpansToCache {
|
||||
|
||||
@Value("${petclinic.outboudExternalService.serviceType:ehcache}")
|
||||
String serviceType;
|
||||
|
||||
@Value("${petclinic.outboudExternalService.ApplicationName:Cache}")
|
||||
String applicationName;
|
||||
|
||||
@Value("${petclinic.inboudExternalService.ComponentName:ehcache}")
|
||||
String componentName;
|
||||
|
||||
final Tracer tracer;
|
||||
|
||||
public AddSpansToCache(Tracer tracer) {
|
||||
this.tracer = tracer;
|
||||
}
|
||||
|
||||
@Around("@annotation(org.springframework.cache.annotation.Cacheable)")
|
||||
public Object AddSpan(ProceedingJoinPoint joinpoint) throws Throwable {
|
||||
|
||||
String joinPointName = joinpoint.getSignature().toString();
|
||||
Span newSpan = this.tracer.nextSpan().name(joinPointName).start();
|
||||
|
||||
newSpan.kind(Kind.CLIENT);
|
||||
newSpan.tag("_outboundExternalService", serviceType);
|
||||
newSpan.tag("_externalApplication", applicationName);
|
||||
newSpan.tag("_externalComponent", componentName);
|
||||
try {
|
||||
return joinpoint.proceed();
|
||||
}
|
||||
catch (RuntimeException | Error e) {
|
||||
newSpan.error(e);
|
||||
throw e;
|
||||
}
|
||||
finally {
|
||||
newSpan.finish();
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
Loading…
Reference in a new issue