Метод @Async
в классе @Service
-annotated не вызывается асинхронно - он блокирует поток.
У меня есть <task: annotation-driven />
в моей конфигурации, и вызов метода поступает извне класса, поэтому прокси-сервер должен быть поражен. Когда я просматриваю код, прокси-сервер действительно попадает, но он, похоже, не приближается ни к каким классам, связанным с запуском в исполнителе задач.
Я поставил точки останова в AsyncExecutionInterceptor
, и они никогда не попадают. Я отлаживался в AsyncAnnotationBeanPostProcessor
и вижу, как применяется обращение к советам.
Служба определяется как интерфейс (с помощью метода annotated @Async
там для хорошей меры) с помощью метода реализации, аннотированного @Async
. Не отмечены @Transactional
.
Любые идеи, что могло пойти не так?
- = ОБНОВЛЕНИЕ = -
Любопытно, что он работает только тогда, когда у меня есть мои XML-элементы task
в моем файле app-servlet.xml, а не в моем файле app-services.xml, и если я тоже просматриваю свой компонент, просматривая службы. Обычно у меня есть один XML файл, в котором есть только контроллеры (и соответственно ограничить его), а другой - с услугами в нем (опять же с ограниченным просмотром компонентов, чтобы он не пересканировал контроллеры, загруженные в другой файл).
приложение-servlet.xml
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:jee="http://www.springframework.org/schema/jee"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:webflow="http://www.springframework.org/schema/webflow-config"
xmlns:task="http://www.springframework.org/schema/task"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
http://www.springframework.org/schema/task
http://www.springframework.org/schema/task/spring-task-3.0.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd
http://www.springframework.org/schema/jee
http://www.springframework.org/schema/jee/spring-jee-3.0.xsd"
>
<task:annotation-driven executor="executor" />
<task:executor id="executor" pool-size="7"/>
<!-- Enable controller annotations -->
<context:component-scan base-package="com.package.store">
<!-- <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller" /> -->
</context:component-scan>
<tx:annotation-driven/>
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"/>
</bean>
<mvc:annotation-driven conversion-service="conversionService" />
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/jsp/" />
<property name="suffix" value=".jsp" />
</bean>
app-services.xml (не работает, если указано здесь)
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context" xmlns:task="http://www.springframework.org/schema/task"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/task
http://www.springframework.org/schema/task/spring-task-3.0.xsd">
<!-- Set up Spring to scan through various packages to find annotated classes -->
<context:component-scan base-package="com.package.store">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller" />
</context:component-scan>
<task:annotation-driven executor="han" />
<task:executor id="han" pool-size="6"/>
...
Я пропустил что-то совершенно очевидное в моей конфигурации, или происходит какое-то тонкое взаимодействие между элементами конфигурации?