系统上线后,偶尔出现一些小的问题,逻辑处理是先更新数据,在发MQ消息,正常情况下,只要没有网络问题或者超时等问题,数据都能保存成功,紧接着就是发送消息,但是偶尔会出现数据保存失败,事务回滚,但是消息却发出去了!!(或者更新之后事务没提交,mq就已经发送出去了)
所以鉴于代码不完善,需要对发消息做逻辑处理,
解决方案:
1、在开发时为了方便就直接让查询业务延迟查询,不过这种方法不太可能在实际部署时用到,影响性能
2、在事务提交后再去执行发送消息
TransactionSynchronizationManager.registerSynchronization(new AbstractAfterCommitTransactionSynchronization() {
@Override
public void afterCommit() {
WsAdminInspectionRecord wsAdminInspectionRecord1 = wsAdminInspectionRecordMapper.selectById(merchantOrderId1);
mqService.sendUtils(merchantOrderId1,
wsAdminInspectionRecord1.getDetectType(),
wsAdminInspectionRecord1.getOssName(),
wsAdminInspectionRecord1.getTemplateId(),
wsAdminInspectionRecord1.getFileName());
}
});
逻辑中增加了AbstractAfterCommitTransactionSynchronization抽象类,用于事务成功提交后,在执行发送消息,代码如下:
package com.ws.common.config.activemq;
import org.springframework.transaction.support.TransactionSynchronization;
/**
* 用于事务成功提交后,在执行发送消息
*
* @author zc
* @mail zhangcongovo@163.com
* @date 2022/4/15.
*/
public abstract class AbstractAfterCommitTransactionSynchronization implements TransactionSynchronization {
@Override
public void suspend() {
}
@Override
public void resume() {
}
@Override
public void flush() {
}
@Override
public void beforeCommit(boolean readOnly) {
}
@Override
public void beforeCompletion() {
}
@Override
public void afterCompletion(int status) {
}
}