a系统给b系统转100块钱,如如何实现?

文章目录

  • 1a系统给b系统转100块钱,如如何实现?从三个方面: 数据如何保证一致性,性能优化,cas锁
    • 1.1 数据的一致性
    • 1.2 性能优化:
    • 1.3 多个线程访问时,保证数据的幂等性

1a系统给b系统转100块钱,如如何实现?从三个方面: 数据如何保证一致性,性能优化,cas锁

a系统给b系统转100块钱,如如何实现?_第1张图片
设置数据库连接只有两个。
买完商品之后,调用第三方发货。
当有两个商品发货时,还有人在调用查询商品的接口,就会报500===》 没有而外的数据库连接了。

1.1 数据的一致性

加了transaction注解,保证了数据的一致性。

虽然加了transaction注解,保证了数据的一致性。但是大大消耗了性能问题:调用其他系统消耗时间太多,导致其他调用不了接口。
a系统给b系统转100块钱,如如何实现?_第2张图片

1.2 性能优化:

编程式事务
通过transactionTemplate控制事务的代码块。
给某些片段加事务。最耗费时间的调用第三方接口的地方,并没有事务,不占用数据库连接。其他地方几乎不耗费时间。
a系统给b系统转100块钱,如如何实现?_第3张图片
调第三方系统之前,吧用户的递交信息先保存起来:正在处理中。
当物流系统的接口挂掉,她的信息状态仍然时正在处理中。
当第二天物流系统的接口好了之后,任务调度自动查询一下 因为服务挂掉而失败的,重新调用。不用用户重复调用。减轻了用户的工作量。
所以在用户调用第三方系统之前,很有必要吧状态先保存下来。

1.3 多个线程访问时,保证数据的幂等性

调用第三方系统时,重复调用了6次,相当于6个线程访问。==》 一个物品发货6次,显然时不正确的,造成了重复发货。没有保证数据的幂等性。

解决;用锁的机制保证
a系统给b系统转100块钱,如如何实现?_第4张图片
a系统给b系统转100块钱,如如何实现?_第5张图片

解释:
a系统给b系统转100块钱,如如何实现?_第6张图片

你可能感兴趣的:(Java面试)