TransactionSynchronizationManager.registerSynchronization( new TransactionSynchronizationAdapter() {
@Override
public void afterCommit()
{
applicationContext.publishEvent( event );// 发送事件
}
} );
PS:
spring 在发送事务(applicationContext.publishEvent( event );)和@EventListener本来是拥有一个事务,
但是, 我们在保证事务执行成功之后再去接受事务,导致没有in progress的事务。所以如果需要在@EventListener端再去提交事务(保存数据),需要在方法上加上@Transactional(propagation=Propagation.REQUIRES_NEW)。
如果需要手动开启事务,可以使用Spring的PlatformTransactionManager 接口,
@Autowired
private PlatformTransactionManager transactionManager;
try{
DefaultTransactionDefinition def = new DefaultTransactionDefinition();
def.setPropagationBehavior( TransactionDefinition.PROPAGATION_REQUIRES_NEW );// 事务隔离级别,开启新事务
TransactionStatus status = transactionManager.getTransaction( def );//获取事务状态,并开启事务,相当于transation.begin();
saveMethod();// 逻辑保存数据的代码
transactionManager.commit( status ); //提交事务
}
catch(Exception e)
{
transactionManager.rollback( status ); // 事务回滚
}
本人java初级,如果有人看到,欢迎补充,欢迎拍砖。