Я пытаюсь создать аспект таймера для измерения времени выполнения методов.Aspect не работает с приложением Spring boot с внешним банком
Я создал аннотацию с именем @Timer
:
@Retention(RetentionPolicy.RUNTIME)
@Target(value = {ElementType.METHOD, ElementType.TYPE})
public @interface Timer {
String value();
}
И тогда я создал аспект следующим образом:
@Aspect
public class MetricAspect {
@Autowired
private MetricsFactory metricsFactory;
@Pointcut("@annotation(my.package.Timer)")
public void timerPointcut() {}
@Around("timerPointcut() ")
public Object measure(ProceedingJoinPoint joinPoint) throws Throwable {
/* Aspect logic here */
}
private Timer getClassAnnotation(MethodSignature methodSignature) {
Timer annotation;
Class<?> clazz = methodSignature.getDeclaringType();
annotation = clazz.getAnnotation(Timer.class);
return annotation;
}
У меня есть класс конфигурации следующим образом:
@Configuration
@EnableAspectJAutoProxy
public class MetricsConfiguration {
@Bean
public MetricAspect notifyAspect() {
return new MetricAspect();
}
}
Все до тех пор, пока здесь не определено в упакованном банке, который Я использую в качестве зависимости в моем весеннем приложении загрузки
В моей весной загрузки приложения я импортировать MetricsConfiguration
и я отлаживается код и увидел, что MetricAspect
компонент создается.
Я использую его в коде следующим образом:
@Service
public class MyService {
...
@Timer("mymetric")
public void foo() {
// Some code here...
}
...
}
Но мой код не доходит до метода measure
. Не уверен, что мне не хватает.
Для завершения картины, у меня есть эта зависимость в моем файле п добавил:
<dependencies>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.7.4</version>
</dependency>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjrt</artifactId>
<version>1.7.4</version>
</dependency>
</dependencies>
Это @Configuration
класса, который импортирует MetricsConfiguration
:
@Configuration
@EnableAspectJAutoProxy
@Import(MetricsConfiguration.class)
@PropertySource("classpath:application.properties")
public class ApplicationConfiguration {
}
Это загружено автомагический конфигурации загрузки в Spring.
У вас также есть весна-аспекты зависимость? –
Я попытался добавить его, и он тоже не сработал:/ – Avi
Почему вы используете отражение, чтобы получить аннотацию? Вы можете просто добавить его к параметрам метода консультаций и получить доступ к нему напрямую. – sheltem