NoSuchBeanDefinitionException при использовании Aspect

Используемая версия загрузки Spring: 1.2.3

Мы создаем CacheManager на основе такого свойства, как:

@Bean
public CacheManager cacheManager() throws IOException {
    String cacheImpl = env.getProperty(CacheSupport.CACHE_PROPERTY, String.class, "");
    if (CacheSupport.AEROSPIKE.equalsIgnoreCase(cacheImpl)) {
        return aerospikeCacheManager();
    } else if (CacheSupport.REDIS.equalsIgnoreCase(cacheImpl)) {
        return redisCacheManager();
    } else {
        return guavaCacheManager();
    }
}

У нас есть AerospikeController, как показано ниже:

@ConditionalOnProperty(name = CacheSupport.CACHE_PROPERTY, havingValue = CacheSupport.AEROSPIKE)
@Controller
public class AerospikeController {
  @Autowired
    private AerospikeCacheManager aerospikeCacheManager;
}

Дела шли нормально. Проблема возникает, когда я добавил ниже код для перехвата времени отклика на вызовы aerospike:

@Component

@Aspect открытый класс WebServiceResponseTimeLogger {

private static final Logger LOG = LoggerFactory.getLogger(WebServiceResponseTimeLogger.class);

@Autowired
private AerospikeCacheManager cacheManager;

@PostConstruct
void init() {
    LOG.info("WebServiceRequestTimeLogger initialized");
}

public WebServiceResponseTimeLogger() {
    super();
}

@Pointcut("execution(* com.snapdeal.pie.web.aerospike.config.AerospikeCacheManager.*(..))")
public void pointcuts() {
}

@Around("pointcuts()")
public void logExternalCalls(ProceedingJoinPoint pjp) throws Throwable {
    long timeStartInMillisecs = System.currentTimeMillis();
    pjp.proceed();
    MethodSignature signature = (MethodSignature) pjp.getSignature();
    LOG.info("Time Taken to execute : {} {} is {} ms", new Object[] { signature, pjp.getArgs()[0], (System.currentTimeMillis() - timeStartInMillisecs) });
}

}

Я получаю исключение ниже:

Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [com.snapdeal.pie.web.aerospike.config.AerospikeCacheManager] found for dependency: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)}
at org.springframework.beans.factory.support.DefaultListableBeanFactory.raiseNoSuchBeanDefinitionException(DefaultListableBeanFactory.java:1301)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:1047)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:942)
at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:533)
... 18 common frames omitted

person Sahil Gupta    schedule 20.05.2016    source источник
comment
Добавьте @Qualifier(value = cacheManager) в свой автоматически подключенный CacheManager в вашем AeospikeController или переименуйте имя переменной в cacheManager.   -  person K. Bastian    schedule 20.05.2016


Ответы (1)


Из логов написано:

Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [com.snapdeal.pie.web.aerospike.config.AerospikeCacheManager] found for dependency: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)}

Проверьте, правильно ли создан бин AerospikeCacheManager в этом коде.

@Bean
public CacheManager cacheManager() throws IOException {
    String cacheImpl = env.getProperty(CacheSupport.CACHE_PROPERTY, String.class, "");
    if (CacheSupport.AEROSPIKE.equalsIgnoreCase(cacheImpl)) {
        return aerospikeCacheManager();
person shankarsh15    schedule 20.05.2016
comment
Да, бин был успешно создан. Когда я удалил код аспекта, все работает нормально. - person Sahil Gupta; 20.05.2016