我正在尝试使用Spring3.0提供的@Async注解来创建一个异步方法
我已经完成了以下工作
在我的module-context.xml中包含以下内容
<task:executor id="initiateContactCreation" pool-size="2-10" queue-capacity="5"/>
<task:annotation-driven executor="initiateContactCreation" />使用@Async的带注释的方法
@Async
private void initiateContactCreation(String fromUserId, List<String> toUsers){
logger.info("Inside Async method for contact creation");
ContactDetails contactDetails = new ContactDetails();
contactDetails.setUserId(fromUserId);
contactDetails.setContactEmailIds(toUsers.toArray(new String[toUsers.size()]));
this.contactsAndDirSvc.addContact(contactDetails);
logger.info("Returning from Async method for contact creation");
}但是我看到这个方法并没有立即返回控制。
我的记录器显示来自initiateContactCreation的日志,然后显示来自addContact的日志(PS。执行此方法需要一些时间,我不希望它同步执行),然后从我调用initiateContactCreation的方法中记录日志
我做错了什么?
发布于 2014-05-01 02:10:58
因为这个方法是私有的,所以我假设你是使用' this‘引用从这个类中调用这个方法的。Spring不能代理类中的调用。调用必须来自类的外部,这样Spring才能拦截并应用注释和其他它所做的代理内容。
发布于 2014-05-01 04:29:51
https://stackoverflow.com/questions/23394999
复制相似问题