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