情况一:
客户端---------(调用)----------> 服务端 (服务端处理超时,但服务端整个事务处理正常且数据修改正常)。此情况,无影响。
情况二:
服务端A-----------(调用)----------->服务端 B (服务端A在整个事务的最后调用服务B)
template.execute(new TransactionCallbackWithoutResult(){
try{
.....A事务......
.....A事务......
.....B事务......
} catch(){
transactionStatus.setRollbackOnly();
throw new RuntimeException(e.getMessage());
}
});
情况二---1、当A事务执行成功,B事务执行失败,则回滚时只会A事务回滚,此时A事务、B事务都会回滚,不会造成数据异常。
情况二---2、当A事务执行成功,B事务执行超时但是数据修改成功,A这边接受到的信息是B执行失败,此时A事务回滚。则此时,A数据回滚到原来状态,B修改数据成功,造成数据异常。(目前解决办法修改数据(******))
情况三:
template.execute(new TransactionCallbackWithoutResult(){
try{
.....B事务......
.....A事务......
.....A事务......
} catch(){
transactionStatus.setRollbackOnly();
throw new RuntimeException(e.getMessage());
}
});
这种情况下,先调用B事务,当B事务执行成功,再往下执行时,如果出现异常,回滚时,只是回滚A事务,B事务,无法回滚。
综上所述,一般情况,都是将B事务写在最后,降低数据异常的风险。情况二---2 的解决办法是增加超时时间,目前已增加到5分钟,出现异常的情况已降到最小了。。。。。。