事务回滚,同时记录异常信息
需求
在发生异常时,回滚对数据库的操作,同时在数据库中插入一条异常信息。
实现原理
开启新的事务,进行异常信息的数据库操作
实现
1、依赖HTTP重新发送请求
在抛出异常前,依赖http,发送一条异步请求,由一个接口保存异常信息,然后主程序再抛出异常。
2、开启新事务,插入异常信息
@Autowired
private DataSourceTransactionManager dstManager;
@Transactional
@Override
public void create(Payment payment) throws Exception {
try {
paymentDao.create(payment);
System.out.println(1 / 0);
} catch (Exception e) {
TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
//此处可添加抛出异常信息,不影响现有逻辑
} finally {
// 事物隔离级别,开启新事务,这样会比较安全些。
DefaultTransactionDefinition def = new DefaultTransactionDefinition();
def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRES_NEW);
// 获得事务状态
TransactionStatus transaction = dstManager.getTransaction(def);
try {
payment.setSerial("报错啦啦啦啦啦啦");
paymentDao.create(payment);
dstManager.commit(transaction);
} catch (Exception e) {
dstManager.rollback(transaction);
logger.error("临时表插入失败:" + e.getMessage(), e);
}
}
}
一种实现方式,与上面的代码思想是一样的
@Transactional
@Override
public void create(Payment payment) {
paymentDao.create1(payment);
paymentService.newTransCreate(payment);
System.out.println(1 / 0);
}
@Override
@Transactional(propagation = Propagation.REQUIRES_NEW, rollbackFor = Exception.class)
public void newTransCreate(Payment payment) {
payment.setSerial("这是一个新的报错信息");
paymentDao.create2(payment);
}