Spring专题
在Spring中使用异步事件实现同步事务
结合Scala+Spring,我们将采取一个很简单的场景:下订单,然后发送一封电子邮件。
编制一个服务:
@Service
class OrderService @Autowired() (orderDao: OrderDao, mailNotifier: OrderMailNotifier) {
@Transactional
def placeOrder(order: Order) {
orderDao save order //保存订单
mailNotifier sendMail order //发送邮件
}
}
上面代码是在保存订单和发送邮件两个同步执行,发送邮件需要连接邮件服务器,比较耗时,拖延了整个性能,我们采取异步发送电子邮件,利用Spring内置的自定义事件,与JMS或其他生产者 - 消费者类似。
case class OrderPlacedEvent(order: Order) extends ApplicationEvent
@Service
class OrderService @Autowired() (orderDao: OrderDao, eventPublisher: ApplicationEventPublisher) {
@Transactional
def placeOrder(order: Order) {
orderDao save order
eventPublisher publishEvent OrderPlacedEvent(order)
}
}
区别是继承了ApplicationEvent 之前是直接用 OrderMailNotifier 直

本文介绍了如何在Spring框架中利用异步事件来处理同步事务,以提高性能。通过实例展示了如何在下单服务中,将保存订单与发送邮件进行异步处理,避免邮件发送耗时导致性能下降。文章详细解释了使用TaskExecutor实现异步事件发布,并讨论了在事务处理中可能出现的竞争条件问题,提出了解决方案。
最低0.47元/天 解锁文章
1079

被折叠的 条评论
为什么被折叠?



